Save Presentations in Python

Overview

Open a Presentation in Python described how to use the Presentation class to open a presentation. This article explains how to create and save presentations. The Presentation class contains a presentation’s contents. Whether you’re creating a presentation from scratch or modifying an existing one, you’ll want to save it when you’re finished. With Aspose.Slides for Python, you can save to a file or stream. This article explains the different ways to save a presentation.

Save Presentations to Files

Save a presentation to a file by calling the Presentation class’s save method. Pass the file name and save format to the method. The following example show how to save a presentation with Aspose.Slides for Python.

import aspose.slides as slides

# Instantiate the Presentation class that represents a presentation file.
with slides.Presentation() as presentation:
    
    # Do some work here...

    # Save the presentation to a file.
    presentation.save("output.pptx", slides.export.SaveFormat.PPTX)

Save Presentations to Streams

You can save a presentation to a stream by passing an output stream to the Presentation class’s save method. A presentation can be written to many stream types. In the example below, we create a new presentation, add text to a shape, and save it to a stream.

import aspose.slides as slides

# Instantiate the Presentation class that represents a presentation file.
with slides.Presentation() as presentation:
    with open("output.pptx", "bw") as file_stream:
        # Save the presentation to the stream.
        presentation.save(file_stream, slides.export.SaveFormat.PPTX)

Save Presentations with a Predefined View Type

Aspose.Slides for Python lets you set the initial view that PowerPoint uses when the generated presentation opens through the ViewProperties class. Set the last_view property to a value from the ViewType enumeration.

import aspose.slides as slides

with slides.Presentation() as presentation:
    presentation.view_properties.last_view = slides.ViewType.SLIDE_MASTER_VIEW
    presentation.save("slide_master_view.pptx", slides.export.SaveFormat.PPTX)

Save Presentations in the Strict Office Open XML Format

Aspose.Slides lets you save a presentation in the Strict Office Open XML format. Use the PptxOptions class and set its conformance property when saving. If you set Conformance.ISO_29500_2008_STRICT, the output file is saved in the Strict Office Open XML format.

The example below creates a presentation and saves it in the Strict Office Open XML format.

import aspose.slides as slides

options = slides.export.PptxOptions()
options.conformance = slides.export.Conformance.ISO_29500_2008_STRICT

# Instantiate the Presentation class that represents a presentation file.
with slides.Presentation() as presentation:
    # Save the presentation in the Strict Office Open XML format.
    presentation.save("strict_office_open_xml.pptx", slides.export.SaveFormat.PPTX, options)

Save Presentations in Office Open XML Format in Zip64 Mode

An Office Open XML file is a ZIP archive that imposes 4 GB (2^32 bytes) limits on the uncompressed size of any file, the compressed size of any file, and the total size of the archive, and it also limits the archive to 65,535 (2^16-1) files. ZIP64 format extensions raise these limits to 2^64.

The PptxOptions.zip_64_mode property lets you choose when to use ZIP64 format extensions when saving an Office Open XML file.

This property provides the following modes:

  • IF_NECESSARY uses ZIP64 format extensions only if the presentation exceeds the limitations above. This is the default mode.
  • NEVER never uses ZIP64 format extensions.
  • ALWAYS always uses ZIP64 format extensions.

The following code demonstrates how to save a presentation as PPTX with ZIP64 format extensions enabled:

pptx_options = slides.export.PptxOptions()
pptx_options.zip_64_mode = slides.export.Zip64Mode.ALWAYS

with slides.Presentation("sample.pptx") as presentation:
    presentation.save("output_zip64.pptx", slides.export.SaveFormat.PPTX, pptx_options)

Save Presentations without Refreshing the Thumbnail

The PptxOptions.refresh_thumbnail property controls thumbnail generation when saving a presentation to PPTX:

  • If set to True, the thumbnail is refreshed during save. This is the default.
  • If set to False, the current thumbnail is preserved. If the presentation has no thumbnail, none is generated.

In the code below, the presentation is saved to PPTX without refreshing its thumbnail.

import aspose.slides as slides

pptx_options = slides.export.PptxOptions()
pptx_options.refresh_thumbnail = False

with slides.Presentation("sample.pptx") as presentation:
    presentation.save("output.pptx", slides.export.SaveFormat.PPTX, pptx_options)