Python读取Excel数据实现批量生成PPT

作者:J哥 时间:2021-03-05 23:57:35 

背景

大家好,我是J哥。

我们常常面临着大量的重复性工作,通过人工方式处理往往耗时耗力易出错。而Python在办公自动化方面具有天然优势,分分钟解决你的办公需求,提前下班不是梦。

需求

前几天我发表了一篇办公自动化文章Python读取Excel数据并批量生成合同,获得许多小伙伴的认可和喜欢。其中有一位粉丝提议,能否出一篇PPT自动化的教程,通过读取Excel数据批量生成幻灯片。于是,我以豆瓣电影数据为例进行了PPT自动化制作,先看看最终效果:

Python读取Excel数据实现批量生成PPT

准备

PPT数据

我们首先需要准备填充PPT的数据,我这里用的是豆瓣电影数据,共有25条电影信息,包含title,director,date,country,types共5个字段,存储方式为Excel。数据预览如下:

Python读取Excel数据实现批量生成PPT

另外,由于PPT还需要批量插入图片,因此我这里也准备了25张电影海报图片,存放在文件夹movie_pic中。

Python读取Excel数据实现批量生成PPT

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

标签:Python,批量,PPT
0
投稿

猜你喜欢

  • javascript基础之数组(Array)对象

    2008-06-25 13:32:00
  • python中*args与**kwarsg及闭包和装饰器的用法

    2023-07-24 00:43:34
  • 浅说相册图片详情页面中大图的浏览方式

    2009-02-01 18:34:00
  • Oracle9i数据库异常关闭后的启动

    2010-07-21 12:46:00
  • 对python借助百度云API对评论进行观点抽取的方法详解

    2023-12-06 19:42:12
  • Win7或Windows server 2008中IIS7支持ASP+Access解决方法

    2012-03-27 18:31:27
  • php中重定向网页跳转方法总结案例教程

    2023-06-11 20:47:18
  • Python简单进程锁代码实例

    2022-06-23 00:45:22
  • python-字典dict和集合set

    2021-09-30 10:10:17
  • 深入浅出Python中三个图像增强库的使用

    2021-12-08 08:33:55
  • 如何解决国外空间显示乱码问题

    2007-11-18 14:28:00
  • Python3.x爬虫下载网页图片的实例讲解

    2022-11-25 23:24:07
  • .NET 2.0获取配置文件AppSettings和ConnectionStrings节数据的方法

    2023-06-30 11:34:10
  • sql之IN和BETWEEN条件运算

    2007-09-11 13:35:00
  • 详解python读写json文件

    2022-11-01 16:18:53
  • Sql Server、Oracle以及Access数据库 判断字段是否为空的办法 (From calmzeal's code life)

    2011-02-24 19:44:00
  • 分享十款最出色的PHP安全开发库中文详细介绍

    2023-06-15 01:04:59
  • 如何用ASP建立Index Server查询对象并为其参数赋值?

    2010-06-11 19:59:00
  • SQL Server取得网站路径的几种方法及比较

    2008-12-09 14:15:00
  • PHP访问MySQL查询超时处理的方法

    2023-11-23 03:05:48
  • asp之家 网络编程 m.aspxhome.com