python office库使用_看完这篇Python操作PPT总结,从此使用Python玩转Office全家桶就没有压力了!...
一、导读
大家好,今天依旧是Python办公自动化基础系列,在之前我们分别详细讲解了
今天本文将基于第三方库pptx,详细讲解如何使用Python操作Office全家桶最后一位——PPT。
二、安装
pptx是一个非标准库,需要在命令行中安装pip 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
从幻灯片母版中确定一个版式
在不同的占位符中填写不同的内容
添加图片、表格等额外内容
对样式进行修改
四、Python读取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 的结构就很好理解了。每一个幻灯片页都有一个或者多个形状shapefor 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 = '...'
六、修改 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的常见方法总结,处理日常办公绝对没有问题,更多详细的代码可以查阅官方文档。
python office库使用_看完这篇Python操作PPT总结,从此使用Python玩转Office全家桶就没有压力了!...相关推荐
- python 只循环目录_看完这篇文章,你的Python基础就差不多了
世界那么大,谢谢你来看我!!关注我你就是个网络.电脑.手机小达人 前言 本文是基于黑马程序员2019年的Python基础班的内容编写的,以2019年的资料为蓝本,2018年的资料为补充,还参考了一些网 ...
- 收藏!最详细的Python全栈开发指南 看完这篇你还不会Python全栈开发 你来打我!!!
Python Web全栈开发入门实战教程教程 大家好,我叫亓官劼(qí guān jié ),这个<Python Web全栈开发入门实战教程教程>是一个零基础的实战教程,手把手带你开 ...
- python的ppt报告_看完这篇Python操作PPT总结,从此使用Python玩转Office全家桶就没有压力了!...
一.导读 大家好,今天依旧是Python办公自动化基础系列,在之前我们分别详细讲解了 今天本文将基于第三方库pptx,详细讲解如何使用Python操作Office全家桶最后一位--PPT. 二.安装 ...
- redis hashmap过期_看完这篇再也不怕 Redis 面试了
0.前言 Redis是跨语言的共同技术点,无论是Java还是C++都会问到,所以是个高频面试点. 笔者是2017年才开始接触Redis的,期间自己搭过单机版和集群版,不过现在 大一些的 公司都完全是运 ...
- python开发office插件_看完这篇Python操作PPT总结,从此使用Python玩转Office全家桶就没有压力了!...
一.导读 大家好,今天依旧是Python办公自动化基础系列,在之前我们分别详细讲解了 今天本文将基于第三方库pptx,详细讲解如何使用Python操作Office全家桶最后一位--PPT. 二.安装 ...
- python基础教程多少页_看完这篇文章,你的Python基础就差不多了(附200页《Python400集》)...
说干就干.经过将一个多月的素材整理.编写.打磨,在上周末终于完成了. 写完它的时候,我很兴奋,因为它将是第一本系统介绍 Python技巧使用的中文教程. 它不仅适用于一个刚入坑 Python ,还未接 ...
- python释放变量内存_看完2019年阿里巴巴Python面试题详解,月薪3万不是梦
很多人想自学Python找工作,下面给大家分享一部分阿里巴巴的Python开发工程师的面试题目: 概念理解类题目: 1.请说一下你对迭代器和生成器的区别? 答:(1)迭代器是一个更抽象的概念,任何对象 ...
- python泰勒公式法求正弦函数_看完这篇让你高数不挂科之——泰勒公式
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天的文章我们来讨论大名鼎鼎的泰勒公式,泰勒公式真的非常有名,我相信上过高数课的一定都记得它的大名.即使你翘掉了所有的课,也一定会在考前重点 ...
- Python是什么?Python有哪些优势?看完这篇清晰多了
人生苦短,我学Python. 近年来,随着人工智能的发展掀起了世界的新一波科技浪潮,而Python作为人工智能的首选语言,也是一路高歌猛进,成功的窜上"最火编程语言"的宝座. 那么 ...
最新文章
- 微信小程序下拉刷新真机无法弹回
- oracle数据库性能awr,常见问题:如何使用AWR报告来诊断数据库性能问题
- java将数据封装为树结构_JAVA代码实现多级树结构封装对象
- 沃信科技ERP系统容灾方案概述
- 要想能安心,必须先死心。
- svn 单独导出某一个目录文件
- C/C++初学者快速提升?
- 飞鸽传书2014提前发布?
- 分离链接法的删除操作函数
- Response.AddHeader
- 使用wireshark分析HTTPS流程的建立
- dos2unix命令
- 通俗理解贝叶斯,全概率定理
- 备战BAT面试-死磕mysql|mysql 是如何做到存储两千万数据毫无压力的?
- 人世之厄人性之恶——陈应松《母亲》读后
- Docker的安装以及常用的一些命令
- 【Vue作业]---Vue登录注册界面
- 浏览器和服务器之间的通信
- Black Duck
- Java题目训练——星际密码和数根