在 Python 中保存演示文稿
概述
在 Python 中打开演示文稿 描述了如何使用 Presentation 类打开演示文稿。本文说明了如何创建和保存演示文稿。Presentation 类包含演示文稿的内容。无论是从头创建演示文稿还是修改现有演示文稿,完成后都需要保存。使用 Aspose.Slides for Python,您可以保存到 文件 或 流。本文解释了保存演示文稿的不同方式。
将演示文稿保存为文件
通过调用 Presentation 类的 save 方法将演示文稿保存为文件。将文件名和保存格式传递给该方法。以下示例展示了如何使用 Aspose.Slides for Python 保存演示文稿。
import aspose.slides as slides
# 实例化代表演示文稿文件的 Presentation 类。
with slides.Presentation() as presentation:
# 在此执行一些操作...
# 将演示文稿保存到文件。
presentation.save("output.pptx", slides.export.SaveFormat.PPTX)
将演示文稿保存到流
通过向 Presentation 类的 save 方法传递输出流,可以将演示文稿保存到流。演示文稿可以写入多种流类型。下面的示例创建了一个新演示文稿,向形状添加文本,并将其保存到流。
import aspose.slides as slides
# 实例化表示演示文稿文件的 Presentation 类。
with slides.Presentation() as presentation:
with open("output.pptx", "bw") as file_stream:
# 将演示文稿保存到流中。
presentation.save(file_stream, slides.export.SaveFormat.PPTX)
使用预定义视图类型保存演示文稿
Aspose.Slides for Python 允许您通过 ViewProperties 类设置 PowerPoint 打开生成的演示文稿时的初始视图。将 last_view 属性设置为 ViewType 枚举中的值。
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)
以 Strict Office Open XML 格式保存演示文稿
Aspose.Slides 允许您以 Strict Office Open XML 格式保存演示文稿。使用 PptxOptions 类并在保存时设置其 conformance 属性。如果将 Conformance.ISO_29500_2008_STRICT 设为 true,则输出文件将以 Strict Office Open XML 格式保存。
下面的示例创建一个演示文稿并以 Strict Office Open XML 格式保存。
import aspose.slides as slides
options = slides.export.PptxOptions()
options.conformance = slides.export.Conformance.ISO_29500_2008_STRICT
# 实例化表示演示文稿文件的 Presentation 类。
with slides.Presentation() as presentation:
# 将演示文稿保存为 Strict Office Open XML 格式。
presentation.save("strict_office_open_xml.pptx", slides.export.SaveFormat.PPTX, options)
以 Zip64 模式在 Office Open XML 格式下保存演示文稿
Office Open XML 文件是一个 ZIP 存档,对任意文件的未压缩大小、压缩大小以及存档的总大小都限制为 4 GB(2^32 字节),并且文件数量限制为 65 535(2^16‑1)。ZIP64 格式扩展将这些限制提升到 2^64。
PptxOptions.zip_64_mode 属性允许您在保存 Office Open XML 文件时选择何时使用 ZIP64 格式扩展。
此属性提供以下模式:
IF_NECESSARY仅当演示文稿超过上述限制时才使用 ZIP64 格式扩展。这是默认模式。NEVER从不使用 ZIP64 格式扩展。ALWAYS始终使用 ZIP64 格式扩展。
下面的代码演示了如何在启用 ZIP64 格式扩展的情况下将演示文稿保存为 PPTX:
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)
在不刷新缩略图的情况下保存演示文稿
PptxOptions.refresh_thumbnail 属性控制在将演示文稿保存为 PPTX 时是否生成缩略图:
- 设置为
True时,保存期间会刷新缩略图。这是默认值。 - 设置为
False时,保留当前缩略图。如果演示文稿没有缩略图,则不生成。
下面的代码将演示文稿保存为 PPTX,且不刷新其缩略图。
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)
Info
此选项有助于减少以 PPTX 格式保存演示文稿所需的时间。Info
Aspose 开发了一个使用其自有 API 的 免费 PowerPoint 拆分工具。该应用可通过将选定的幻灯片另存为新的 PPTX 或 PPT 文件,将演示文稿拆分为多个文件。常见问题
是否支持“快速保存”(增量保存),仅写入更改内容?
不支持。每次保存都会创建完整的目标文件,未提供增量“快速保存”。
从多个线程同时保存同一 Presentation 实例是否线程安全?
不安全。Presentation 实例 不是线程安全的(/slides/python-net/multithreading/),请在单个线程中保存。
保存时超链接和外部链接文件会怎样处理?
超链接 会被保留。外部链接文件(例如通过相对路径引用的视频)不会自动复制——请确保引用的路径仍可访问。
是否可以设置/保存文档元数据(作者、标题、公司、日期)?
可以。标准的 文档属性 受支持,保存时会写入文件。