Python办公神器:教你使用python批量制作PPT

Python办公神器:教你使用python批量制作PPT

介绍

  • 本文将介绍如何使用openpyxlpptx库来批量制作PPT奖状。
  • 本文假设你已经安装了python和这两个库。
  • 本文的场景是:一名基层人员,要给一次比赛活动获奖的500名选手制作奖状,并且奖状需要做成PPT在颁奖大会上电子展示,手上有一份名单 list.xlsx 和 PPT 奖状模板 temp.pptx

准备工作

  • 首先,我们需要导入openpyxlpython-pptx库,以及其他一些辅助库,如下:
python 复制代码
import openpyxl
from pptx import Presentation
from pptx.util import Inches, Pt
import os
  • 然后,我们需要定义一些常量,如文件名,字体,颜色等,如下:
python 复制代码
# 文件名
EXCEL_FILE = 'list.xlsx'
PPT_FILE = 'temp.pptx'
OUTPUT_DIR = 'output'

# 字体
FONT_NAME = '微软雅黑'
FONT_SIZE = 36
FONT_COLOR = 'FFFFFF'

# 占位符索引
NAME_INDEX = 0
AWARD_INDEX = 1
DATE_INDEX = 2
  • 接下来,我们需要读取Excel文件,获取获奖者的姓名,奖项,以及日期,如下:
python 复制代码
# 读取Excel文件
wb = openpyxl.load_workbook(EXCEL_FILE)
ws = wb.active

# 获取获奖者列表
awardees = []
for row in ws.iter_rows(min_row=2, values_only=True):
    name, award, date = row
    awardees.append((name, award, date))
  • 最后,我们需要创建一个输出目录,用来存放生成的PPT文件,如下:
python 复制代码
# 创建输出目录
if not os.path.exists(OUTPUT_DIR):
    os.mkdir(OUTPUT_DIR)

生成PPT奖状

  • 首先,我们需要加载PPT模板文件,获取幻灯片母版,以及占位符对象,如下:
python 复制代码
# 加载PPT模板文件
prs = Presentation(PPT_FILE)

# 获取幻灯片母版
slide_layout = prs.slide_layouts[0]

# 获取占位符对象
placeholders = slide_layout.placeholders
  • 然后,我们需要遍历获奖者列表,为每个获奖者生成一个PPT奖状,如下:
python 复制代码
# 遍历获奖者列表
for name, award, date in awardees:
    # 生成一个PPT奖状
    slide = prs.slides.add_slide(slide_layout)

    # 填充姓名
    name_placeholder = slide.placeholders[NAME_INDEX]
    name_placeholder.text = name
    name_placeholder.font.name = FONT_NAME
    name_placeholder.font.size = Pt(FONT_SIZE)
    name_placeholder.font.color.rgb = FONT_COLOR

    # 填充奖项
    award_placeholder = slide.placeholders[AWARD_INDEX]
    award_placeholder.text = award
    award_placeholder.font.name = FONT_NAME
    award_placeholder.font.size = Pt(FONT_SIZE)
    award_placeholder.font.color.rgb = FONT_COLOR

    # 填充日期
    date_placeholder = slide.placeholders[DATE_INDEX]
    date_placeholder.text = date
    date_placeholder.font.name = FONT_NAME
    date_placeholder.font.size = Pt(FONT_SIZE)
    date_placeholder.font.color.rgb = FONT_COLOR
  • 最后,我们需要保存生成的PPT文件,如下:
python 复制代码
# 保存生成的PPT文件
output_file = os.path.join(OUTPUT_DIR, 'awards.pptx')
prs.save(output_file)

总结

  • 本文介绍了如何使用openpyxlpython-pptx库来批量制作PPT奖状。
  • 本文通过一个实际的场景,演示了如何读取Excel文件,写入PPT文件,以及使用PPT占位符来填充内容。
相关推荐
IT_10241 小时前
Spring Boot项目开发实战销售管理系统——系统设计!
大数据·spring boot·后端
ai小鬼头2 小时前
AIStarter最新版怎么卸载AI项目?一键删除操作指南(附路径设置技巧)
前端·后端·github
Touper.2 小时前
SpringBoot -- 自动配置原理
java·spring boot·后端
一只叫煤球的猫3 小时前
普通程序员,从开发到管理岗,为什么我越升职越痛苦?
前端·后端·全栈
一只鹿鹿鹿3 小时前
信息化项目验收,软件工程评审和检查表单
大数据·人工智能·后端·智慧城市·软件工程
专注VB编程开发20年3 小时前
开机自动后台运行,在Windows服务中托管ASP.NET Core
windows·后端·asp.net
程序员岳焱3 小时前
Java 与 MySQL 性能优化:MySQL全文检索查询优化实践
后端·mysql·性能优化
一只叫煤球的猫4 小时前
手撕@Transactional!别再问事务为什么失效了!Spring-tx源码全面解析!
后端·spring·面试
旷世奇才李先生4 小时前
Ruby 安装使用教程
开发语言·后端·ruby
沃夫上校7 小时前
Feign调Post接口异常:Incomplete output stream
java·后端·微服务