转载请注明:陈熹 chenx6542@foxmail.com (简书号:半为花间酒)
若公众号内转载请联系公众号:早起Python
文中的截图均为原创,转载请注明来源
之前我们已经学习了
openpyxl
和python-docx
操作 Excel 和 Word 文件,为了巩固先前的知识以及加深今天的学习理解,我们更多利用 类比 的方法来讲述python-pptx
模块
一、安装
pptx
是一个非标准库,需要在命令行中安装
命令行:
- Windows:徽标键 + R —— 输入cmd + 回车
pip install python-pptx
- Mac:打开终端/Terminal输入
pip3 install python-pptx
- 要注意,安装的时候是
python-pptx
,而实际调用时均为pptx
。这里和docx
模块相同
二、前置知识
1. 基本结构
再看一下ppt结构组成,会较word复杂许多。当然这也跟ppt的高度自定义拓展性有关
简单来说,一个PPT文件为presentation,基本的结构为展示文件 presentation - 幻灯片页 slide - 形状 shape组成,形状就需要区分开,是包含文本的形状还是不包含文本的形状(纯图片等)。如果是包含文本的形状,则可以获取内部的文本框,一个文本框又可以看作是一个小的word文档,包含段落 paragraph - 文字块 run
对 Office 三件套的结构组成做一个小总结:
2. 模板和占位符
如图所示,通过幻灯片母版我们可以预设好各种各样的版式,后面新建幻灯片的时候只需要点击版式就可以一键生成所需的基本格式
接着说说占位符 Placeholder:
占位符已经完成了样式设置,包括字体、字号、颜色等等,在特定占位符内输入文字可直接转化为特定的样式
3. 创建 PPT 文件的基本思路
- 创建一个 PPT
- 从幻灯片母版中确定一个版式
- 在不同的占位符中填写不同的内容
- 添加图片、表格等额外内容
- 对样式进行修改
三、读取 PPT
1. 打开 PPT 文件
from pptx import Presentation
# 这里给出需要打开的文件路径
file_path = r'...'
pptx = Presentation(file_path)
2. 获取幻灯片页
用 pptx.slides
可以获得一个列表,包括所有的幻灯片页 slide 对象
for slide in pptx.slides:
print(slide)
3. 获取形状
只要熟悉了类似 Excel 和 Word 的多级结构, PPT 的结构就很好理解了。每一个幻灯片页都有一个或者多个形状 shape
for slide in pptx.slides:
for shape in slide.shapes:
print(shape)
4. 获取文本框内容
要获取文字内容,很容易就联系到文字在形状 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
shape.has_text_frame
判断形状中是否有文字框
shape.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)
到这里,我们需要对先前对 PPT 结构的认识进行修正:
5. 获取段落和文字块
每一个文本框都可以看成是一个小的 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 文件的代码,实例化的过程中不给予具体路径则为创建空白文件
1. 创建幻灯片页
其中占位符编号是区分占位符的依据,也是写入内容的依据
2. 往占位符填写内容
指定占位符编号就可以在具体位置写入特定内容
slide.placeholders[占位符编号].text = '...'
任何写入的操作都切记保存:
pptx.save(new_file_path)
五、 修改 PPT 样式
1. 段落样式修改
可以同 python-docx
模块对段落样式的导入进行类比
具体的方法上二者也有很多相似:
-
.add_run()
:添加新的文字块 -
.line_spacing
:段内行间距 -
.runs
:段落内的所有文字块 -
.space_after
:段后距 -
.space_before
:段前距
2. 文字样式修改
文字样式方法和 Word 中的使用是相同的:
-
.font.name
:字体名称 -
.font.bold
:是否加粗 -
.font.italic
:是否斜体 -
.font.color
:字体颜色 -
.font.size
:字体大小
但有一个地方需要加以区别:在 python-pptx
中,使用文字样式方法是基于段落,也就是 paragraph.font.xxxx
, 而在 python-docx
中,使用文字样式方法是基于文字块
以上只是对 python-pptx
模块操作 PPT 文件的简单入门,更多代码参见:https://python-pptx.readthedocs.io/en/latest/