脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|shell|

服务器之家 - 脚本之家 - Python - Python读取Excel数据实现批量生成PPT

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

2023-02-22 12:14J哥 Python

我们常常面临着大量的重复性工作,通过人工方式处理往往耗时耗力易出错。而Python在办公自动化方面具有天然优势。本文将利用读取Excel数据并实现批量生成PPT,需要的可以参考一下

背景

大家好,我是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)

以上就是Python读取Excel数据实现批量生成PPT的详细内容,更多关于Python生成PPT的资料请关注服务器之家其它相关文章!

原文链接:https://mp.weixin.qq.com/s/-ShPlalTLoCfcbpLu59uUQ

延伸 · 阅读

精彩推荐
  • Pythonpython pytest进阶之conftest.py详解

    python pytest进阶之conftest.py详解

    这篇文章主要介绍了python pytest进阶之conftest.py详解,如果我们在编写测试用的时候,每一个测试文件里面的用例都需要先登录后才能完成后面的操作,那么们...

    linux超9142021-07-25
  • PythonPython自定义函数定义,参数,调用代码解析

    Python自定义函数定义,参数,调用代码解析

    这篇文章主要介绍了Python自定义函数定义,参数,调用代码解析,具有一定借鉴价值,需要的朋友可以参考下。...

    feesland7962020-12-29
  • Python一篇文章告诉你如何用Python控制Excel实现自动化办公

    一篇文章告诉你如何用Python控制Excel实现自动化办公

    这篇文章主要介绍了教你怎么用Python处理excel实现自动化办公,文中有非常详细的代码示例,对正在学习python的小伙伴们有非常好的帮助,需要的朋友可以参考...

    程序媛小墨4242021-12-20
  • Pythonpython字符串操作

    python字符串操作

    这篇文章主要介绍了python字符串操作,主要包括字符串的分割、字符串的查找,替换、字符串的判断,下面一起进入文章了解具体内容,需要的朋友可以参考...

    全菜小能手5442022-02-26
  • Python详解配置Django的Celery异步之路踩坑

    详解配置Django的Celery异步之路踩坑

    这篇文章主要介绍了详解配置Django的Celery异步之路踩坑,分享一下自己遇见的坑,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编...

    奶牛博客6572021-04-22
  • PythonPython创建自己的加密货币的示例

    Python创建自己的加密货币的示例

    这篇文章主要介绍了Python创建自己的加密货币的示例,帮助大家更好的理解和学习使用python,感兴趣的朋友可以了解下...

    链三丰8852021-09-12
  • Pythonpycharm部署django项目到云服务器的详细流程

    pycharm部署django项目到云服务器的详细流程

    今天重点给大家介绍pycharm部署django项目到云服务器的详细流程,首先大家需要先下载python3.8压缩包,然后通过一系列命令完成操作,具体实现方法,跟随小...

    Akiyama_6832021-12-09
  • PythonPython 设计模式中命令模式

    Python 设计模式中命令模式

    这篇文章主要介绍了Python 设计模式中的命令模式,命令模式的目的是解耦调用操作的对象和提供实现的对象,下文介绍具有一定参考价值,需要的小伙伴可...

    范桂飓4512022-09-27