在 Python 中管理演示文稿幻灯片母版

概述

幻灯片母版 定义了一组幻灯片的共享设计设置。它可以包含通用形状、徽标、背景、文本样式、主题设置以及页脚设置。在 PowerPoint 中,编辑幻灯片母版是保持演示文稿一致性的常用方式,而无需在每张幻灯片上重复相同的格式设置。

Aspose.Slides for Python via .NET 支持相同的模型。一个演示文稿可以包含一个或多个母版幻灯片,每个母版幻灯片可以包含若干版式幻灯片。普通幻灯片通常不会直接引用母版幻灯片,而是使用版式幻灯片,而该版式幻灯片属于某个母版幻灯片。

层级结构如下:

  1. 幻灯片母版 – 定义共享的设计和主题。
  2. 版式幻灯片 – 定义占位符的具体排列以及版式级别的格式。
  3. 普通幻灯片 – 包含实际的演示内容,并使用一个版式幻灯片。

母版幻灯片、版式幻灯片和普通幻灯片的层级结构

在 Aspose.Slides 中,幻灯片母版由 MasterSlide 类表示。演示文稿中的所有母版幻灯片可通过 Presentation.masters 集合访问。

访问幻灯片母版

在 PowerPoint 中,可通过 视图 > 幻灯片母版 打开幻灯片母版视图。

PowerPoint 视图选项卡上的 幻灯片母版 命令

在 Aspose.Slides 中,使用 masters 集合访问母版幻灯片:

您也可以通过普通幻灯片的版式获取其使用的母版幻灯片:

import aspose.slides as slides

with slides.Presentation("presentation.pptx") as presentation:
    slide = presentation.slides[0]
    layout_slide = slide.layout_slide
    master_slide = layout_slide.master_slide
    master_slide_name = master_slide.name

    print(master_slide_name)

幻灯片母版包含的内容

母版幻灯片是一种类似幻灯片的对象。它从 BaseSlide 类继承通用幻灯片行为,因此暴露出许多普通幻灯片和版式幻灯片使用的相同属性。母版特有的成员列在 MasterSlide API 页面上。

常用的母版幻灯片成员包括:

成员 用途
background 设置母版级别的幻灯片背景。
shapes 存储放置在母版上的形状,如徽标、图片框和共享文本。
layout_slides 存储属于该母版的版式幻灯片。
theme_manager 提供对母版主题 API 的访问。
header_footer_manager 控制母版及其子版式的页眉、页脚、日期和页码。
get_depending_slides 返回通过其版式依赖于该母版的普通幻灯片。

向幻灯片母版添加图片

向母版幻灯片添加图片后,使用该母版的版式的幻灯片都会显示该图片,这对于徽标、水印、装饰条带以及其他重复视觉元素非常有用。

下面的示例向第一个母版幻灯片添加徽标:

import aspose.slides as slides

with slides.Presentation("presentation.pptx") as presentation:
    master_slide = presentation.masters[0]

    with open("logo.png", "rb") as logo_stream:
        logo_bytes = logo_stream.read()

    logo_image = presentation.images.add_image(logo_bytes)

    master_slide.shapes.add_picture_frame(
        slides.ShapeType.RECTANGLE,
        20,
        20,
        80,
        80,
        logo_image)

    presentation.save("presentation-with-logo.pptx", slides.export.SaveFormat.PPTX)

有关图片框的更多信息,请参阅 Picture Frame

使用占位符

占位符通常在版式幻灯片上定义。母版幻灯片提供共享的样式和主题,版式则决定哪些占位符可用以及它们的放置位置。

在 PowerPoint 中,占位符命令位于幻灯片母版视图中。

PowerPoint 幻灯片母版视图中的 插入占位符 命令

要使用 Aspose.Slides 添加新占位符,请操作属于母版的版式幻灯片:

import aspose.slides as slides

with slides.Presentation("presentation.pptx") as presentation:
    master_slide = presentation.masters[0]
    blank_layout_slide = master_slide.layout_slides.get_by_type(slides.SlideLayoutType.BLANK)

    if blank_layout_slide is None:
        blank_layout_slide = presentation.layout_slides.add(
            master_slide,
            slides.SlideLayoutType.BLANK,
            "Blank")

    blank_layout_slide.placeholder_manager.add_text_placeholder(60, 120, 600, 80)

    presentation.slides.add_empty_slide(blank_layout_slide)
    presentation.save("presentation-with-placeholder.pptx", slides.export.SaveFormat.PPTX)

您也可以格式化已经存在于母版上的占位符形状。下面的示例查找标题占位符并应用线性渐变填充:

import aspose.pydrawing as draw
import aspose.slides as slides


def find_placeholder(master_slide, placeholder_type):
    for shape in master_slide.shapes:
        if isinstance(shape, slides.AutoShape) and shape.placeholder is not None:
            if shape.placeholder.type == placeholder_type:
                return shape

    return None


with slides.Presentation("presentation.pptx") as presentation:
    master_slide = presentation.masters[0]
    title_placeholder = find_placeholder(master_slide, slides.PlaceholderType.TITLE)

    if title_placeholder is not None:
        red_gradient_color = draw.Color.from_argb(255, 0, 0)
        purple_gradient_color = draw.Color.from_argb(128, 0, 128)

        title_placeholder.fill_format.fill_type = slides.FillType.GRADIENT
        title_placeholder.fill_format.gradient_format.gradient_shape = slides.GradientShape.LINEAR
        title_placeholder.fill_format.gradient_format.gradient_stops.add(0, red_gradient_color)
        title_placeholder.fill_format.gradient_format.gradient_stops.add(255, purple_gradient_color)

    presentation.save("presentation-title-style.pptx", slides.export.SaveFormat.PPTX)

普通幻灯片继承的已格式化标题占位符

有关占位符和文本格式的更多选项,请参阅 Set Prompt Text in PlaceholderText Formatting

更改幻灯片母版背景

母版背景会被版式和未覆盖它的幻灯片继承。以下示例为第一个母版幻灯片设置纯色背景:

import aspose.pydrawing as draw
import aspose.slides as slides

with slides.Presentation("presentation.pptx") as presentation:
    master_slide = presentation.masters[0]

    master_slide.background.type = slides.BackgroundType.OWN_BACKGROUND
    master_slide.background.fill_format.fill_type = slides.FillType.SOLID
    master_slide.background.fill_format.solid_fill_color.color = draw.Color.forest_green

    presentation.save("presentation-master-background.pptx", slides.export.SaveFormat.PPTX)

相关主题请参阅 Presentation BackgroundPresentation Theme

将幻灯片母版克隆到其他演示文稿

使用 MasterSlideCollection 类的 add_clone 方法,可将母版幻灯片复制到另一个演示文稿中。复制后的母版随后可以被目标演示文稿中的版式和幻灯片使用。

import aspose.slides as slides

with slides.Presentation("source.pptx") as source_presentation:
    with slides.Presentation("destination.pptx") as destination_presentation:
        source_master_slide = source_presentation.masters[0]
        cloned_master_slide = destination_presentation.masters.add_clone(source_master_slide)

        destination_presentation.save("destination-with-master.pptx", slides.export.SaveFormat.PPTX)

如果需要将普通幻灯片连同其母版一起克隆,请参阅 Clone Slides

添加多个幻灯片母版

一个演示文稿可以包含多个母版幻灯片。这在不同章节需要不同品牌、页面结构或主题设置时非常有用。

PowerPoint 插入和管理母版幻灯片的命令

下面的示例克隆默认母版,给克隆的母版设置不同的背景,获取该克隆母版下的空白版式,并基于该版式添加新幻灯片:

import aspose.pydrawing as draw
import aspose.slides as slides

with slides.Presentation("presentation.pptx") as presentation:
    default_master_slide = presentation.masters[0]
    section_master_slide = presentation.masters.add_clone(default_master_slide)

    section_master_slide.background.type = slides.BackgroundType.OWN_BACKGROUND
    section_master_slide.background.fill_format.fill_type = slides.FillType.SOLID
    section_master_slide.background.fill_format.solid_fill_color.color = draw.Color.light_steel_blue

    section_blank_layout = section_master_slide.layout_slides.get_by_type(slides.SlideLayoutType.BLANK)

    if section_blank_layout is None:
        section_blank_layout = presentation.layout_slides.add(
            section_master_slide,
            slides.SlideLayoutType.BLANK,
            "Section Blank")

    presentation.slides.add_empty_slide(section_blank_layout)
    presentation.save("presentation-with-multiple-masters.pptx", slides.export.SaveFormat.PPTX)

比较幻灯片母版

母版幻灯片可以使用从 BaseSlide 类继承的 equals 方法进行比较。比较会检查结构和静态内容,如形状、文本、格式、动画以及其他幻灯片设置。它不比较唯一标识符(如幻灯片 ID)或动态占位符值(如当前日期)。

import aspose.slides as slides

with slides.Presentation("first.pptx") as first_presentation:
    with slides.Presentation("second.pptx") as second_presentation:
        first_presentation_master_count = len(first_presentation.masters)
        second_presentation_master_count = len(second_presentation.masters)

        for first_master_index in range(first_presentation_master_count):
            for second_master_index in range(second_presentation_master_count):
                first_master_slide = first_presentation.masters[first_master_index]
                second_master_slide = second_presentation.masters[second_master_index]
                are_master_slides_equal = first_master_slide.equals(second_master_slide)

                if are_master_slides_equal:
                    print(
                        "first.pptx master #{} equals second.pptx master #{}".format(
                            first_master_index,
                            second_master_index))

更多信息请参阅 Compare Presentation Slides

将幻灯片母版视图设为默认视图

使用演示文稿的 ViewProperties 中的 last_view 属性,可控制 PowerPoint 首次打开时的视图。下面的示例在打开演示文稿时直接进入幻灯片母版视图:

import aspose.slides as slides

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

更多视图设置请参阅 Save Presentation

移除未使用的母版幻灯片

有时演示文稿中会存在不再被任何普通幻灯片使用的母版幻灯片。移除未使用的母版可以减小文件大小并简化模板维护。

使用 remove_unused 方法可从 masters 集合中移除未使用的母版:

import aspose.slides as slides

with slides.Presentation("presentation.pptx") as presentation:
    presentation.masters.remove_unused(True)
    presentation.save("presentation-clean.pptx", slides.export.SaveFormat.PPTX)

您也可以使用 Compress 类中的低代码 remove_unused_master_slides 方法:

import aspose.slides as slides

with slides.Presentation("presentation.pptx") as presentation:
    slides.lowcode.Compress.remove_unused_master_slides(presentation)
    presentation.save("presentation-clean.pptx", slides.export.SaveFormat.PPTX)

常见问题

幻灯片母版和版式幻灯片有什么区别?

幻灯片母版定义共享的设计设置,如主题、背景、通用形状和文本样式。版式幻灯片属于某个母版,定义占位符的具体排列。普通幻灯片使用版式幻灯片,从而同时继承版式和母版的设置。

一个演示文稿可以包含多个幻灯片母版吗?

可以。一个演示文稿可以包含多个幻灯片母版。当不同章节需要不同的视觉系统或品牌时,请使用多个母版。

应该在母版幻灯片还是版式幻灯片上添加占位符?

大多数情况下,应在版式幻灯片上添加占位符。将共享的视觉元素和共享格式放在母版上,然后在普通幻灯片将使用的版式上放置内容占位符。

我可以删除仍在使用中的母版幻灯片吗?

不能。拥有依赖幻灯片的母版不能直接安全删除。请先将这些幻灯片移动到另一个母版的版式下,或使用只删除未使用母版的清理方法。