在 Python 中格式化演示文稿文本
概览
本文展示了如何使用 Aspose.Slides for Python via .NET 对 PowerPoint 和 OpenDocument 演示文稿中的文本进行格式化。内容涵盖突出显示、背景颜色、透明度、字符间距、字体属性、旋转、段落间距、自动适配行为、文本锚点、制表位以及语言设置。
在下面的示例中,我们将使用名为 sample.pptx 的文件,该文件在第一页幻灯片上包含一个带有以下文本的单个文本框:

突出显示文本
在需要突出显示文本框中与特定样本匹配的文本时,使用 TextFrame.highlight_text 方法。该方法会为匹配的文本片段应用突出显示颜色,并可结合 TextSearchOptions 控制搜索方式,例如仅匹配完整单词。
下面的代码示例先突出显示所有 “try” 字符,然后仅突出显示完整单词 “to”。
import aspose.pydrawing as draw
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
# 获取第一张幻灯片上的第一个形状。
shape = presentation.slides[0].shapes[0]
# 在形状中突出显示单词 "try"。
shape.text_frame.highlight_text("try", draw.Color.light_blue)
search_options = slides.TextSearchOptions()
search_options.whole_words_only = True
# 在形状中突出显示单词 "to"。
shape.text_frame.highlight_text("to", draw.Color.violet, search_options, None)
presentation.save("highlighted_text.pptx", slides.export.SaveFormat.PPTX)
结果:

使用正则表达式突出显示文本
TextFrame.highlight_regex 方法会突出显示正则表达式匹配的文本。在 Python 中,此 API 在 TextFrame 上公开。
下面的代码示例突出显示所有包含 七个或更多字符 的单词:
import aspose.pydrawing as draw
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
shape = presentation.slides[0].shapes[0]
regex = r"\b[^\s]{7,}\b"
# 突出显示所有包含七个或更多字符的单词。
shape.text_frame.highlight_regex(regex, draw.Color.yellow, None)
presentation.save("highlighted_text_using_regex.pptx", slides.export.SaveFormat.PPTX)
结果:

设置文本背景颜色
使用 ParagraphFormat.default_portion_format 为段落设置默认突出显示颜色,或使用 PortionFormat.highlight_color 为单个文本片段设置颜色。
下面的代码示例展示如何为 整个段落 设置背景颜色:
import aspose.pydrawing as draw
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
# 设置整个段落的突出显示颜色。
paragraph.paragraph_format.default_portion_format.highlight_color.color = draw.Color.light_gray
presentation.save("gray_paragraph.pptx", slides.export.SaveFormat.PPTX)
结果:

下面的代码示例演示如何为 粗体字的文本片段 设置背景颜色:
import aspose.pydrawing as draw
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
for portion in paragraph.portions:
if portion.portion_format.get_effective().font_bold:
# 设置文本片段的突出显示颜色。
portion.portion_format.highlight_color.color = draw.Color.light_gray
presentation.save("gray_text_portions.pptx", slides.export.SaveFormat.PPTX)
结果:

对齐文本段落
使用 ParagraphFormat.alignment 设置文本框内段落的对齐方式。可设置为居中、左对齐、右对齐、两端对齐等。
下面的代码示例展示如何将段落对齐到 居中:
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
# 将段落的对齐方式设置为居中。
paragraph.paragraph_format.alignment = slides.TextAlignment.CENTER
presentation.save("aligned_paragraph.pptx", slides.export.SaveFormat.PPTX)
结果:

设置文本透明度
文本透明度通过分配给 PortionFormat.fill_format 的颜色的 alpha 分量来控制。下面示例中的 alpha = 50 是 0-255 范围的 ARGB alpha 通道值,而非透明度百分比。
下面的代码示例展示如何为 整个段落 应用透明度:
import aspose.pydrawing as draw
import aspose.slides as slides
alpha = 50
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
# 将文本的填充颜色设置为透明颜色。
paragraph.paragraph_format.default_portion_format.fill_format.fill_type = slides.FillType.SOLID
paragraph.paragraph_format.default_portion_format.fill_format.solid_fill_color.color = draw.Color.from_argb(alpha, draw.Color.black)
presentation.save("transparent_paragraph.pptx", slides.export.SaveFormat.PPTX)
结果:

下面的代码示例展示如何为 粗体字的文本片段 应用透明度:
import aspose.pydrawing as draw
import aspose.slides as slides
alpha = 50
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
for portion in paragraph.portions:
if portion.portion_format.get_effective().font_bold:
# 设置文本片段的透明度。
portion.portion_format.fill_format.fill_type = slides.FillType.SOLID
portion.portion_format.fill_format.solid_fill_color.color = draw.Color.from_argb(alpha, draw.Color.black)
presentation.save("transparent_text_portions.pptx", slides.export.SaveFormat.PPTX)
结果:

设置文本字符间距
使用 BasePortionFormat.spacing 可以在文本框中扩展或压缩字符之间的间距。
下面的 Python 代码展示如何在 整个段落 中扩展字符间距:
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
# 注意: 使用负值来压缩字符间距。
paragraph.paragraph_format.default_portion_format.spacing = 3 # 扩展字符间距。
presentation.save("character_spacing_in_paragraph.pptx", slides.export.SaveFormat.PPTX)
结果:

下面的代码示例展示如何在 粗体字的文本片段 中扩展字符间距:
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
for portion in paragraph.portions:
if portion.portion_format.get_effective().font_bold:
# 注意: 使用负值来压缩字符间距。
portion.portion_format.spacing = 3 # 扩展字符间距。
presentation.save("character_spacing_in_text_portions.pptx", slides.export.SaveFormat.PPTX)
结果:

禁用特定字体的字距调整
在某些情况下,Aspose.Slides 渲染的文本可能比 PowerPoint 中显示的稍微紧凑。这可能是因为 PowerPoint 会忽略某些字体的字距调整数据,即使该字体包含有效的字距信息并在 PowerPoint 设置中启用了字距调整。
为使渲染结果更接近 PowerPoint,您可以为使用受影响字体的文本片段禁用字距调整。将 PortionFormat.kerning_minimal_size 设置为远大于实际字体大小的值:
import aspose.slides as slides
with slides.Presentation("presentation.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
target_font = "Roboto"
for paragraph in auto_shape.text_frame.paragraphs:
for portion in paragraph.portions:
latin_font = portion.portion_format.latin_font
east_asian_font = portion.portion_format.east_asian_font
complex_script_font = portion.portion_format.complex_script_font
if ((latin_font is not None and latin_font.font_name == target_font) or
(east_asian_font is not None and east_asian_font.font_name == target_font) or
(complex_script_font is not None and complex_script_font.font_name == target_font)):
portion.portion_format.kerning_minimal_size = 100
presentation.save("output.pptx", slides.export.SaveFormat.PPTX)
此设置可防止对匹配的文本片段应用字距调整,从而帮助 Aspose.Slides 的渲染效果与 PowerPoint 对受影响字体的视觉输出保持一致。
管理文本字体属性
可以通过 ParagraphFormat.default_portion_format 在段落级别设置字体属性,或通过 PortionFormat 在单个片段上设置。
下面的代码为整个段落设置字体和文本样式:对段落中的所有片段应用字体大小、粗体、斜体、点状下划线以及 Times New Roman 字体。
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
# 设置段落的字体属性。
paragraph.paragraph_format.default_portion_format.font_height = 12
paragraph.paragraph_format.default_portion_format.font_bold = slides.NullableBool.TRUE
paragraph.paragraph_format.default_portion_format.font_italic = slides.NullableBool.TRUE
paragraph.paragraph_format.default_portion_format.font_underline = slides.TextUnderlineType.DOTTED
paragraph.paragraph_format.default_portion_format.latin_font = slides.FontData("Times New Roman")
presentation.save("font_properties_for_paragraph.pptx", slides.export.SaveFormat.PPTX)
结果:

下面的代码示例为 粗体字的文本片段 应用类似属性:
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
for portion in paragraph.portions:
if portion.portion_format.get_effective().font_bold:
# 设置文本片段的字体属性。
portion.portion_format.font_height = 13
portion.portion_format.font_italic = slides.NullableBool.TRUE
portion.portion_format.font_underline = slides.TextUnderlineType.DOTTED
portion.portion_format.latin_font = slides.FontData("Times New Roman")
presentation.save("font_properties_for_text_portions.pptx", slides.export.SaveFormat.PPTX)
结果:

设置文本旋转
使用 TextFrameFormat.text_vertical_type 在形状内设置预定义的文本方向。
下面的代码示例将形状内的文本方向设为 VERTICAL270,即逆时针旋转 90 度:
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
auto_shape.text_frame.text_frame_format.text_vertical_type = slides.TextVerticalType.VERTICAL270
presentation.save("text_rotation.pptx", slides.export.SaveFormat.PPTX)
结果:

为文本框设置自定义旋转
使用 TextFrameFormat.rotation_angle 为 TextFrame 设置自定义旋转角度。
下面的代码示例在形状内将文本框顺时针旋转 3 度:
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
auto_shape.text_frame.text_frame_format.rotation_angle = 3
presentation.save("custom_text_rotation.pptx", slides.export.SaveFormat.PPTX)
结果:

设置段落行间距
Aspose.Slides 提供 ParagraphFormat.space_after、ParagraphFormat.space_before 和 ParagraphFormat.space_within 来控制段落间距。使用方式如下:
- 使用正值将行间距指定为行高的百分比。
- 使用负值将行间距指定为磅值。
下面的代码示例展示如何在段落内指定行间距:
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
paragraph.paragraph_format.space_within = 200
presentation.save("line_spacing.pptx", slides.export.SaveFormat.PPTX)
结果:

设置文本框的自动适配类型
TextFrameFormat.autofit_type 决定当文本超出容器边界时的行为。使用它可以控制文本是收缩、溢出还是自动调整形状大小。
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
auto_shape.text_frame.text_frame_format.autofit_type = slides.TextAutofitType.SHAPE
presentation.save("autofit_type.pptx", slides.export.SaveFormat.PPTX)
设置文本框的锚点
TextFrameFormat.anchoring_type 定义文本在形状内部的垂直定位方式,例如顶部、居中或底部。
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
auto_shape.text_frame.text_frame_format.anchoring_type = slides.TextAnchorType.BOTTOM
presentation.save("text_anchor.pptx", slides.export.SaveFormat.PPTX)
设置文本制表符
使用 ParagraphFormat.default_tab_size 和 ParagraphFormat.tabs 配置段落中的制表位。
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
paragraph.paragraph_format.default_tab_size = 100
paragraph.paragraph_format.tabs.add(30, slides.TabAlignment.LEFT)
presentation.save("paragraph_tabs.pptx", slides.export.SaveFormat.PPTX)
结果:

设置校对语言
Aspose.Slides 提供 PortionFormat.language_id,可为文本片段设置校对语言。校对语言决定 PowerPoint 中拼写和语法检查使用的语言。
下面的代码示例展示如何为文本片段设置校对语言:
import aspose.slides as slides
with slides.Presentation("presentation.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
paragraph = auto_shape.text_frame.paragraphs[0]
paragraph.portions.clear()
font = slides.FontData("SimSun")
text_portion = slides.Portion()
text_portion.portion_format.complex_script_font = font
text_portion.portion_format.east_asian_font = font
text_portion.portion_format.latin_font = font
# 设置校对语言的 Id。
text_portion.portion_format.language_id = "zh-CN"
text_portion.text = "1."
paragraph.portions.add(text_portion)
presentation.save("proofing_language.pptx", slides.export.SaveFormat.PPTX)
设置默认语言
使用 LoadOptions.default_text_language 定义在加载或创建演示文稿时创建的文本的默认语言。
import aspose.slides as slides
load_options = slides.LoadOptions()
load_options.default_text_language = "en-US"
with slides.Presentation(load_options) as presentation:
slide = presentation.slides[0]
# 添加一个带文本的新矩形形状。
shape = slide.shapes.add_auto_shape(slides.ShapeType.RECTANGLE, 20, 20, 150, 50)
shape.text_frame.text = "Sample text"
# 检查第一个片段的语言。
portion = shape.text_frame.paragraphs[0].portions[0]
print(portion.portion_format.language_id)
设置默认文本样式
要在演示文稿级别应用默认文本格式,请使用 Presentation.default_text_style。
下面的代码示例展示如何在新演示文稿中为所有幻灯片的文本设置 14 磅大小、粗体的默认文本样式。
import aspose.slides as slides
with slides.Presentation() as presentation:
# 获取顶层段落格式。
paragraph_format = presentation.default_text_style.get_level(0)
if paragraph_format is not None:
paragraph_format.default_portion_format.font_height = 14
paragraph_format.default_portion_format.font_bold = slides.NullableBool.TRUE
presentation.save("default_text_style.pptx", slides.export.SaveFormat.PPTX)
提取带全大写效果的文本
在 PowerPoint 中,应用 All Caps 字体效果会使文本在幻灯片上显示为大写,即使原始输入为小写。当使用 Aspose.Slides 获取此类文本片段时,库会返回原始输入的文本。若要匹配显示的文本,请检查 TextCapType 并在值为 ALL 时将返回的字符串转换为大写。
假设我们在 sample2.pptx 文件的第一页幻灯片上有如下文本框。

下面的代码示例展示如何提取带 All Caps 效果的文本:
import aspose.slides as slides
with slides.Presentation("sample2.pptx") as presentation:
auto_shape = presentation.slides[0].shapes[0]
text_portion = auto_shape.text_frame.paragraphs[0].portions[0]
print("Original text:", text_portion.text)
text_format = text_portion.portion_format.get_effective()
if text_format.text_cap_type == slides.TextCapType.ALL:
text = text_portion.text.upper()
print("All-Caps effect:", text)
输出:
Original text: Hello, Aspose!
All-Caps effect: HELLO, ASPOSE!
常见问题
如何修改幻灯片上表格中的文本?
要修改幻灯片上表格中的文本,请使用 Table。遍历单元格并通过 Cell.text_frame 更新每个单元格,通过 Paragraph.paragraph_format 更新段落格式。
如何在 PowerPoint 幻灯片中的文本上应用渐变色?
要为文本应用渐变色,请使用 PortionFormat.fill_format。将 FillFormat.fill_type 设置为 FillType.GRADIENT,并配置渐变停靠点、方向和透明度。