在 Python 中将 PPT & PPTX 转换为 PDF | 高级选项
概述
在 Python 中将 PowerPoint 演示文稿(PPT、PPTX、ODP)转换为 PDF 格式具有多种优势,包括确保在不同设备上的兼容性以及保留演示文稿的布局和格式。本指南演示了如何将演示文稿转换为 PDF 文档,使用各种选项控制图像质量、包含隐藏幻灯片、对 PDF 文档设置密码、检测字体替换、选择特定幻灯片进行转换,以及对输出文档应用合规标准。
PowerPoint 转 PDF 转换
使用 Aspose.Slides,您可以将以下格式的演示文稿转换为 PDF:
- PPT
- PPTX
- ODP
要在 Python 中将演示文稿转换为 PDF,只需在 Presentation 类的构造函数中传入文件名,然后使用 Save 方法将演示文稿保存为 PDF。Presentation 类公开了通常用于将演示文稿转换为 PDF 的 Save 方法。
NOTE
Aspose.Slides for Python 会在输出文档中直接写入 API 信息和版本号。例如,在将演示文稿转换为 PDF 时,Aspose.Slides for Python 会在 Application 字段填入 “Aspose.Slides”,在 PDF Producer 字段填入 “Aspose.Slides v XX.XX” 形式的值。注意,您无法指示 Aspose.Slides for Python 更改或删除这些信息。Aspose.Slides 支持以下转换方式:
- 将整个演示文稿导出为 PDF
- 将演示文稿中的特定幻灯片导出为 PDF
Aspose.Slides 将演示文稿导出为 PDF,确保生成的 PDF 内容与原始演示文稿高度匹配。转换过程中准确渲染以下元素和属性:
- 图像
- 文本框和形状
- 文本格式
- 段落格式
- 超链接
- 页眉和页脚
- 项目符号
- 表格
将 PowerPoint 转换为 PDF
标准的 PowerPoint PDF 转换操作使用默认选项执行。在此情况下,Aspose.Slides 会尝试使用最佳设置在最高质量水平上将提供的演示文稿转换为 PDF。下面的 Python 代码演示了如何将 PowerPoint 转换为 PDF:
Steps: PowerPoint to PDF Conversions in Python
以下示例代码通过 .NET 展示了这些转换的 Python 实现
- 步骤:使用 Python via .NET 将 PowerPoint 转换为 PDF
- 步骤:使用 Python via .NET 将 PPT 转换为 PDF
- 步骤:使用 Python via .NET 将 PPTX 转换为 PDF
- 步骤:使用 Python via .NET 将 ODP 转换为 PDF
- 步骤:使用 Python via .NET 将 PPS 转换为 PDF
代码步骤:
- 创建 Presentation 类的实例并提供 PowerPoint 文件。
- .ppt 扩展名用于在 Presentation 类中加载 PPT 文件。
- .pptx 扩展名用于在 Presentation 类中加载 PPTX 文件。
- .odp 扩展名用于在 Presentation 类中加载 ODP 文件。
- .pps 扩展名用于在 Presentation 类中加载 PPS 文件。
- 调用 Save 方法并使用 SaveFormat.PDF 枚举将 Presentation 保存为 PDF 格式。
import aspose.slides as slides
# 实例化一个表示 PowerPoint 文件的 Presentation 类
presentation = slides.Presentation("PowerPoint.ppt")
# 将演示文稿保存为 PDF
presentation.save("PPT-to-PDF.pdf", slides.export.SaveFormat.PDF)
使用选项将 PowerPoint 转换为 PDF
Aspose.Slides 提供了自定义选项——位于 PdfOptions 类下的属性——可让您自定义转换后生成的 PDF、为 PDF 设置密码,甚至指定转换过程的行为。
使用自定义选项将 PowerPoint 转换为 PDF
通过自定义转换选项,您可以设置光栅图像的首选质量、指定元文件的处理方式、设置文本的压缩级别、为图像设置 DPI 等。
下面的代码示例演示了在转换 PowerPoint 为 PDF 时使用多个自定义选项的操作:
import aspose.slides as slides
# 实例化 PdfOptions 类
pdf_options = slides.export.PdfOptions()
# 设置 JPG 图像的质量
pdf_options.jpeg_quality = 90
# 设置图像的 DPI
pdf_options.sufficient_resolution = 300
# 设置元文件的行为
pdf_options.save_metafiles_as_png = True
# 设置文本内容的压缩级别
pdf_options.text_compression = slides.export.PdfTextCompression.FLATE
# 定义 PDF 合规模式
pdf_options.compliance = slides.export.PdfCompliance.PDF15
# 实例化表示 PowerPoint 文档的 Presentation 类
with slides.Presentation("PowerPoint.pptx") as presentation:
# 将演示文稿保存为 PDF 文档
presentation.save("PowerPoint-to-PDF.pdf", slides.export.SaveFormat.PDF, pdf_options)
使用隐藏幻灯片将 PowerPoint 转换为 PDF
如果演示文稿包含隐藏幻灯片,您可以使用自定义选项——PdfOptions 类的 show_hidden_slides 属性——指示 Aspose.Slides 将隐藏幻灯片作为页面包含在生成的 PDF 中。
下面的 Python 代码演示了如何在转换为 PDF 时包含隐藏幻灯片:
import aspose.slides as slides
# 实例化一个表示 PowerPoint 文件的 Presentation 类
presentation = slides.Presentation("PowerPoint.pptx")
# 实例化 PdfOptions 类
pdfOptions = slides.export.PdfOptions()
# 添加隐藏幻灯片
pdfOptions.show_hidden_slides = True
# 将演示文稿保存为 PDF
presentation.save("PowerPoint-to-PDF.pdf", slides.export.SaveFormat.PDF, pdfOptions)
将 PowerPoint 转换为受密码保护的 PDF
下面的 Python 代码演示了如何使用 PdfOptions 类的保护参数,将 PowerPoint 转换为受密码保护的 PDF:
import aspose.slides as slides
# 实例化一个表示 PowerPoint 文件的 Presentation 对象
presentation = slides.Presentation("PowerPoint.pptx")
# 实例化 PdfOptions 类
pdfOptions = slides.export.PdfOptions()
# 设置 PDF 密码和访问权限
pdfOptions.password = "password"
pdfOptions.access_permissions = slides.export.PdfAccessPermissions.PRINT_DOCUMENT | slides.export.PdfAccessPermissions.HIGH_QUALITY_PRINT
# 将演示文稿保存为 PDF
presentation.save("PPTX-to-PDF.pdf", slides.export.SaveFormat.PDF, pdfOptions)
检测字体替换
Aspose.Slides 在 SaveOptions 类下提供了 warning_callback 属性,以便在演示文稿转 PDF 的过程中检测字体替换。
下面的 Python 代码演示了如何检测字体替换:
[TODO[SLIDESPYNET-91]: callbacks are not supported for now]
将 PowerPoint 中选定的幻灯片转换为 PDF
下面的 Python 代码演示了如何将 PowerPoint 演示文稿中的特定幻灯片转换为 PDF:
import aspose.slides as slides
# 实例化一个表示 PowerPoint 文件的 Presentation 对象
presentation = slides.Presentation("PowerPoint.pptx")
# 设置幻灯片位置数组
slides_array = [ 1, 3 ]
# 将演示文稿保存为 PDF
presentation.save("PPTX-to-PDF.pdf", slides_array, slides.export.SaveFormat.PDF)
使用自定义幻灯片尺寸将 PowerPoint 转换为 PDF
下面的 Python 代码演示了在指定幻灯片尺寸的情况下将 PowerPoint 转换为 PDF:
import aspose.slides as slides
slide_width = 612
slide_height = 792
# 实例化表示 PowerPoint 或 OpenDocument 文件的 Presentation 类。
with slides.Presentation("SelectedSlides.pptx") as presentation:
# 创建一个具有调整后幻灯片尺寸的新演示文稿。
with slides.Presentation() as resized_presentation:
# 设置自定义幻灯片尺寸。
resized_presentation.slide_size.set_size(slide_width, slide_height, slides.SlideSizeScaleType.ENSURE_FIT)
# 从原始演示文稿克隆第一张幻灯片。
slide = presentation.slides[0]
resized_presentation.slides.insert_clone(0, slide)
# 将调整大小的演示文稿保存为带备注的 PDF。
resized_presentation.save("PDF_with_notes.pdf", slides.export.SaveFormat.PDF)
在备注幻灯片视图下将 PowerPoint 转换为 PDF
下面的 Python 代码演示了如何在备注视图下将 PowerPoint 转换为 PDF:
import aspose.slides as slides
# 实例化一个表示 PowerPoint 文件的 Presentation 类
presentation = slides.Presentation("NotesFile.pptx")
pdfOptions = slides.export.PdfOptions()
pdfOptions.notes_comments_layouting.notes_position = slides.export.NotesPositions.BOTTOM_FULL
# 将演示文稿保存为 PDF 注释
presentation.Save("Pdf_Notes_out.tiff", slides.export.SaveFormat.PDF, pdfOptions)
PDF 的可访问性和合规标准
Aspose.Slides 允许您使用符合 Web Content Accessibility Guidelines (WCAG) 的转换过程。您可以使用以下任意合规标准将 PowerPoint 文档导出为 PDF:PDF/A1a、PDF/A1b 和 PDF/UA。
下面的 Python 代码演示了基于不同合规标准生成多个 PDF 的 PowerPoint 转 PDF 操作:
import aspose.slides as slides
pres = slides.Presentation("pres.pptx")
options = slides.export.PdfOptions()
options.compliance = slides.export.PdfCompliance.PDF_A1A
pres.save("pres-a1a-compliance.pdf", slides.export.SaveFormat.PDF, options)
options.compliance = slides.export.PdfCompliance.PDF_A1B
pres.save("pres-a1b-compliance.pdf", slides.export.SaveFormat.PDF, options)
options.compliance = slides.export.PdfCompliance.PDF_UA
pres.save("pres-ua-compliance.pdf", slides.export.SaveFormat.PDF, options)
Note
Aspose.Slides 对 PDF 转换操作的支持还扩展到将 PDF 转换为最流行的文件格式。您可以执行 PDF to HTML、PDF to image、PDF to JPG 和 PDF to PNG 转换。对专用格式的其他 PDF 转换操作——PDF to SVG、PDF to TIFF 和 PDF to XML——也受到支持。注意: 导出为 PDF/UA 时,Aspose.Slides 将 SmartArt、图表和公式等复杂图形视为单个图形。单独的路径元素不会保留为独立内容,可能被标记为伪影;仅为整个图形提供替代文本。
常见问题
Aspose.Slides for Python 能否从 PDF 中移除应用程序信息?
不能,Aspose.Slides for Python 会自动在输出 PDF 中包含 API 信息和版本号,该信息无法修改或删除。
如何仅在 PDF 转换中包含特定幻灯片?
您可以通过将幻灯片索引数组传递给 save 方法来指定要转换的幻灯片。
在转换过程中可以对 PDF 设置密码保护吗?
可以,您可以在将演示文稿保存为 PDF 之前使用 PdfOptions 类设置密码并定义访问权限。
Aspose.Slides 是否支持将 PDF 转换为其他格式?
支持,Aspose.Slides 可将 PDF 转换为 HTML、图像格式(JPG、PNG)、SVG、TIFF 和 XML 等。
如何确保我的 PDF 符合可访问性标准?
在 PdfOptions 中将 compliance 属性设置为 PDF_A1A、PDF_A1B 或 PDF_UA 等标准,即可确保符合可访问性指南。
我可以在 PDF 输出中包含隐藏幻灯片吗?
可以,通过将 PdfOptions 中的 show_hidden_slides 属性设为 True,隐藏幻灯片将被包含在 PDF 中。
在转换过程中如何调整图像质量和分辨率?
使用 PdfOptions 中的 jpeg_quality 和 sufficient_resolution 属性可控制生成 PDF 中图像的质量和分辨率。
Aspose.Slides 是否会自动处理字体替换?
Aspose.Slides 在转换过程中会检测字体替换,您可以使用 SaveOptions 中的 warning_callback 属性进行处理(当前功能有限)。