Python读取PPT

1.打开PPT文件

from pptx import Presentation# 这里给出需要打开的文件路径file_path = r'...'pptx = Presentation(file_path)

2. 获取幻灯片页

用pptx.slides可以获得一个列表,包括所有的幻灯片页slide 对象。

forslide inpptx.slides: print(slide)

3. 获取形状

只要熟悉了类似 Excel 和 Word 的多级结构, PPT 的结构就很好理解了。每一个幻灯片页都有一个或者多个形状shape。

forslide inpptx.slides: forshape inslide.shapes: print(shape)

4. 获取文本框内容

要获取文字内容,很容易就联系到文字在形状 shape 的下级结构了 从 Word 中的学习我们也可以推知,文字的承载单位是 段落 paragraph和文字块 run。

很自然可以想到用下列的代码获取文字。

forslide inpptx.slides: forshape inslide.shapes: forparagraph inshape.paragraphs: print(paragraph.text)

或者

forslide inpptx.slides: forshape inslide.shapes: forparagraph inshape.paragraphs: forrun inparagraph.runs: print(run.text)

但这里出现了一个问题:每个形状里一定有文字吗?

python ppt课件 python做的ppt_ide

从上图可以看到,蓝色椭圆的形状里是没有任何文字的,中间的大虚线框有文字。

一个形状中有没有文字,关键就在于它有没有包含文本框text_frame,下面是与文本框有关的操作:

shape.has_text_frame 判断形状中是否有文字框

shape.text_frame 获取文字内容

在PPT中,文字框才是文字的载体,因此获取文字的代码如下:

forslide inpptx.slides: forshape inslide.shapes: ifshape.has_text_frame: text_frame = shape.text_frame print(text_frame.text)

到这里,我们需要对先前对 PPT 结构的认识进行修正:

python ppt课件 python做的ppt_python课件_02

5. 获取段落和文字块

每一个文本框都可以看成是一个小的 Word 文件,里面有段落和文字块两级结构:

forslide inpptx.slides: forshape inslide.shapes: ifshape.has_text_frame: text_frame = shape.text_frame forparagraph intext_frame.paragraphs: forrun inparagraph.runs: print(run.text)

写入 PPT

创建全新 PPT 的代码可以类比创建 Word 文件的代码,实例化的过程中不给予具体路径则为创建空白文件。

1. 创建幻灯片页

python ppt课件 python做的ppt_Word_03

其中占位符编号是区分占位符的依据,也是写入内容的依据。

2. 往占位符填写内容

指定占位符编号就可以在具体位置写入特定内容。

slide.placeholders[占位符编号].text = '...'

修改 PPT 样式

1. 段落样式修改

可以同python-docx模块对段落样式的导入进行类比。

python ppt课件 python做的ppt_占位符_04

具体的方法上二者也有很多相似:

.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 ppt课件 python做的ppt_Word_05

以就是对 python-pptx模块操作PPT的常见方法总结,处理日常办公绝对没有问题,更多详细的代码可以查阅官方文档。

学完了这篇Python操作PPT之后,有关Python操作Word、Excel、PPT、PDF的基础就全部讲解完毕,之后我们会继续更新使用这些工具实现自动化办公的案例