Python读取Excel数据实现批量生成PPT
作者:J哥 发布时间:2021-03-05 23:57:35
背景
大家好,我是J哥。
我们常常面临着大量的重复性工作,通过人工方式处理往往耗时耗力易出错。而Python
在办公自动化方面具有天然优势,分分钟解决你的办公需求,提前下班不是梦。
需求
前几天我发表了一篇办公自动化文章Python读取Excel数据并批量生成合同,获得许多小伙伴的认可和喜欢。其中有一位粉丝提议,能否出一篇PPT自动化的教程,通过读取Excel
数据批量生成幻灯片。于是,我以豆瓣电影数据为例进行了PPT自动化制作,先看看最终效果:
准备
PPT数据
我们首先需要准备填充PPT的数据,我这里用的是豆瓣电影数据,共有25条电影信息,包含title
,director
,date
,country
,types
共5个字段,存储方式为Excel
。数据预览如下:
另外,由于PPT还需要批量插入图片,因此我这里也准备了25张电影海报图片,存放在文件夹movie_pic
中。
PPT模板
我们首先需要新建一个PPT模板,这个操作比较简单,直接进入到PPT母版视图,然后选择模板中第一张幻灯片的布局,依次插入电影名称、图片、类型、主演和导演、年份和国家6个占位符,其中除了图片其他都是内容占位符。这里一定要注意插入的顺序,后面代码也是根据占位符顺序来进行内容填充。为了美化PPT,我们可以个性化添加LOGO,背景图片,设置字体颜色大小等等。
实战
导入相关模块
# 读取图片文件
import os
# 读取Excel数据
import pandas as pd
# 操作PPT
from pptx import Presentation
读取电影数据
用pandas
读取excel
数据,并将数据转为字典格式。
#读取电影数据
df = pd.read_excel(r".\ppt素材\top250.xlsx")
data = df.to_dict('records')
print(data)
读取PPT模板插入数据
用Presentation()
方法读取PPT模板,然后遍历所有电影数据(25个字典),选择母版样式中的第一张幻灯片即layout[0]
,接着遍历幻灯片中的所有占位符,这里用到enumerate()
获取站位符的序号。将每个字典中的值插入到对应的占位符中,最后用save()
方法保存新生成的PPT。
# 读取母版文件构建PPT的对象
my_ppt = Presentation(r".\ppt素材\ppt模板.pptx")
# 获取母版所有幻灯片布局
layout = my_ppt.slide_layouts
# 遍历所有电影数据
for x in data:
#print(x)
#选择模板中第一个幻灯片的布局并创建新幻灯片
slide = my_ppt.slides.add_slide(layout[0])
#当前幻灯片中所有的占位符
placeholders = slide.shapes.placeholders
for i,pl in enumerate(placeholders):
if i == 0:
pl.text = x["title"]
elif i == 2:
pl.text = x["types"]
elif i == 3:
pl.text = x["director"]
elif i == 4:
pl.text = str(x["date"])
elif i == 5:
pl.text = x["country"]
my_ppt.save("result.pptx")
由于图片是单独存放在文件夹movie_pic
中,我们需要os.path.join()
方法拼接每张图片的完整路径,然后用insert_picture()
方法将图片插入到PPT中。
# 电影海报存储路径
images = r".\ppt素材\movie_pic"
# 遍历所有电影数据
for x in data:
slide = my_ppt.slides.add_slide(layout[0])
placeholders = slide.shapes.placeholders
for i,pl in enumerate(placeholders):
if i == 0:
pl.text = x["title"]
elif i == 1:
img_path = os.path.join(images,f'{x["title"]}.jpg')
print(img_path)
pl.insert_picture(img_path)
来源:https://mp.weixin.qq.com/s/-ShPlalTLoCfcbpLu59uUQ


猜你喜欢
- 最初我们介绍到 Matplotlib 可以绘制2D图形,并且介绍了一些常见图形的绘制方法,其实不仅可以绘制2D图形,现在较新版本的 Matp
- 与数据库交互的基本语言是sql,数据库每次解析和执行sql语句多需要执行很多步骤。以sql server为例,当数据库收到一条查询语句时,语
- caller 属性返回一个对函数的引用,该函数调用了当前函数。functionName.caller functionName 对象是所执行
- Python版本 实现了比之前的xxftp更多更完善的功能 1、继续支持多用户 2、继续支持虚拟目录 3、增加支持用户根目录以及映射虚拟目录
- 但是有时候,可以视看处进逻辑程度,可以把三者写成一个触发器,只是在其中稍作判断而已。 你可以根据从下面方法判断触发器是是处理了插入,删除还是
- 1、下载安装MySQLdb类库http://www.djangoproject.com/r/python-mysql/2、修改setting
- 最近发现Python课器做很多事情,在监控服务器有其独特的优势,耗费资源少,开发周期短。首先我们做一个定时或者实时脚本timedtask.p
- 无论使用int还是varchar,对于Status的多选查询都是不易应对的。举例,常规思维下对CustomerStatus的Enum设置如下
- 前言在两种python循环语句的使用中,不仅仅是循环条件达到才能跳出循环体。所以,在对python函数进行阐述之前,先对跳出循环的简单语句块
- 作为一名前端,我们通常要做的就是让页面在各系统A-Grade浏览器,甚至网站浏览份额0.1%以上的浏览器上良好显示。当然,还有性能问题。不过
- golang中list包用法可以参看这篇文章但是list包中大部分对于e *Element进行操作的元素都可能会导致程序崩溃,其根本原因是e
- 正则表达式中的符号符号描述re1 | re2匹配正则表达式 re1 或者 re2 ;re1 与 re2 代表两个匹配的字符串信息^匹配字符串
- 目录1.编写模块结构1.1 git创建空文件1.2 编写包功能函数1.3 包必备函数1、README.md文件是在git上生成的说明项目的文
- 在访问数据库时,特别是新手,可能会需要查询表中数据总数,以下这段代码可以非常简便的获取到数据数目//先建立数据库连接,执行查询语句Conne
- 前言之前写过很多关于扫描脚本的文章,一直都没写自己的扫描IP段是哪里搞来的,也会有朋友经常来问一些扫描经验,说实话我觉得这个工具并没有实际的
- 具体错误:UnicodeEncodeError: 'latin-1' codec can't encode char
- 前言读取站点资料数据对站点数据进行插值,插值到规则网格上绘制EOF第一模态和第二模态的空间分布图绘制PC序列关于插值,这里主要提供了两个插值
- 进行深度学习时,对图像进行预处理的过程是非常重要的,使用pytorch或者TensorFlow时需要对图像进行预处理以及展示来观看处理效果,
- Go语言也称 Golang,兼具效率、性能、安全、健壮等特性。Go语言从底层原生支持并发,无须第三方库、开发者的编程技巧和开发经验就可以轻松
- 案例描述在定时脚本运行过程中,发现当备份表格的sql语句与删除该表部分数据的sql语句同时运行时,mysql会检测出死锁,并打印出日志。两