导读
今天本文将基于第三方库 pptx,详细讲解如何使用Python操作Office全家桶最后一位——PPT。
pptx 是一个非标准库,需要在命令行中安装
pip install python-pptx
要注意,安装的时候是 python-pptx,而实际调用时均为 pptx。这里和 docx模块相同。
再看一下ppt结构组成,会较word复杂许多。当然这也跟ppt的高度自定义拓展性有关
简单来说,一个PPT文件为presentation,基本的结构为展示文件presentation-幻灯片页slide-形状shape组成,形状就需要区分开,是包含文本的形状还是不包含文本的形状(纯图片等)。
如果是包含文本的形状,则可以获取内部的文本框,一个文本框又可以看作是一个小的word文档,包含段落paragraph - 文字块run
接着说说占位符 Placeholder占位符已经完成了样式设置,包括字体、字号、颜色等等,在特定占位符内输入文字可直接转化为特定的样式
from pptx import Presentation
# 这里给出需要打开的文件路径
file_path = r'...'
pptx = Presentation(file_path)
用 pptx.slides 可以获得一个列表,包括所有的幻灯片页 slide 对象
for slide in pptx.slides:
print(slide)
只要熟悉了类似 Excel 和 Word 的多级结构, PPT 的结构就很好理解了。每一个幻灯片页都有一个或者多个形状 shape
for slide in pptx.slides:
for shape in slide.shapes:
print(shape)
要获取文字内容,很容易就联系到文字在形状 shape 的下级结构了 从 Word 中的学习我们也可以推知,文字的承载单位是 段落 paragraph和文字块 run
很自然可以想到用下列的代码获取文字
for slide in pptx.slides:
for shape in slide.shapes:
for paragraph in shape.paragraphs:
print(paragraph.text)
或者
for slide in pptx.slides:
for shape in slide.shapes:
for paragraph in shape.paragraphs:
for run in paragraph.runs:
print(run.text)
但这里出现了一个问题:每个形状里一定有文字吗?从上图可以看到,蓝色椭圆的形状里是没有任何文字的,中间的大虚线框有文字
一个形状中有没有文字,关键就在于它有没有包含文本框 text_frame,下面是与文本框有关的操作:
在PPT中,文字框才是文字的载体,因此获取文字的代码如下:
for slide in pptx.slides:
for shape in slide.shapes:
if shape.has_text_frame:
text_frame = shape.text_frame
print(text_frame.text)
每一个文本框都可以看成是一个小的 Word 文件,里面有段落和文字块两级结构:
for slide in pptx.slides:
for shape in slide.shapes:
if shape.has_text_frame:
text_frame = shape.text_frame
for paragraph in text_frame.paragraphs:
for run in paragraph.runs:
print(run.text)
写入 PPT
创建全新 PPT 的代码可以类比创建 Word 文件的代码,实例化的过程中不给予具体路径则为创建空白文件
其中占位符编号是区分占位符的依据,也是写入内容的依据
指定占位符编号就可以在具体位置写入特定内容
slide.placeholders[占位符编号].text = '...'
可以同 python-docx 模块对段落样式的导入进行类比具体的方法上二者也有很多相似:
文字样式方法和 Word 中的使用是相同的:
但有一个地方需要加以区别:在 python-pptx 中,使用文字样式方法是基于段落,也就是 paragraph.font.xxxx, 而在 python-docx 中,使用文字样式方法是基于文字块学完了这篇Python操作PPT之后,有关Python操作Word、Excel、PPT、PDF的基础就全部讲解完毕,之后我们会继续更新使用这些工具实现自动化办公的案例,如果你还不知道具体该如何应用,下面这些案例可能会有所帮助:
更多精彩推荐
☞JavaScript 爆红后,微软为何还要开发 TypeScript?
☞打通语言理论和统计 NLP 两个世界,Transformers/GNNs 架构能做到吗?
☞区块链+生鲜:杜绝“偷梁换柱”和“以次充好”
点分享 点点赞 点在看