当前位置: 首页 > news >正文

Python读取Excel批量写入到PPT生成词卡

一、问题的提出

有网友想把Excel表中的三列数据,分别是:单词、音标和释义分别写入到PPT当中,每一张PPT写一个单词的内容。这种批量操作是python的强项,尤其是在办公领域,它能较好地解放双手,读取Excel表后,批量写入到PPT的模板中。

词卡

二、分析问题

生成词卡过程中要用到读取Excel的openpyxl模块,以及写入PPT用到的python-pptx模块。先读取单词表,然后把每一行数据存到一个data列表当中,然后利用pptx模块构建对象,获取ppt模板中的第一张幻灯片,以及其母板中的第一个版本。接着遍历data列表,通过添加slide,写入三个占位符中单词、音标和释义等三列数据,最后再保存为单词卡pptx文件。

在编写代码前要先在cmd下安装这两个模块,代码是:

pip install openpyxl, python-pptx

三、解决问题

1. 准备PPT母版

根据以上分析,我们先把PPT模板准备好,在其中的母板上,找到第一个版式,自上而下插入三个占位符,此时还可以设置动画、颜色、字体等格式信息,然后保存。

母版样式

2. 准备单词表

准备好一张Excel表,放入我们准备好的单词表,命名为单词表.xlsx,此表可以有表头,也可以没有表头,为读取和写入数据做准备

Excel数据

3. 写入代码

根据以上分析,我们编写出以下代码:

# 导入必要库
import os
from pptx import Presentation
from openpyxl import load_workbook# 读取 Excel 数据
try:wb = load_workbook(r"单词表.xlsx")sheet = wb.active  # 默认读取第一个工作表
except FileNotFoundError:raise FileNotFoundError("文件 '单词表1.xlsx' 未找到。")# 检查是否有数据
if sheet.max_row < 1:raise ValueError("Excel 文件中没有有效的数据行。")# 将数据按行存储为列表
data = []
for row in sheet.iter_rows(min_row=1, values_only=True):  # 从第1行开始读取数据data.append(row)print(data)# 读取母版文件构建 PPT 的对象
try:my_ppt = Presentation(r"单词模板.pptx")
except FileNotFoundError:raise FileNotFoundError("文件 '单词模板.pptx' 未找到。")# 模板中的第一张幻灯片
sld = my_ppt.slides[0]if sld.shapes[0].has_text_frame:tf = sld.shapes[0].text_frametf.text = "词卡内容"# 获取母版所有幻灯片布局
layout = my_ppt.slide_layouts# 遍历所有数据
for row in data:# 创建新幻灯片slide = my_ppt.slides.add_slide(layout[0])# 当前幻灯片中的占位符placeholders = slide.shapes.placeholdersfor i, pl in enumerate(placeholders,1):if i < len(row):  # 确保占位符对应的数据存在pl.text = str(row[i]) if row[i] is not None else ""else:pl.text = ""  # 如果数据不足,设置为空字符串# 保存最终生成的 PPT
my_ppt.save("单词卡.pptx")

四、注意事项

1. 注意路径为当前路径,生成文件时,一定要保持模板、Excel表都处在关闭的状态当中。

2. 注意模板中第一个版式要插入三个占位符,而不是文本框。

http://www.lryc.cn/news/509322.html

相关文章:

  • NS3学习——tcpVegas算法代码详解(1)
  • 相机雷达外参标定综述“Automatic targetless LiDAR–camera calibration: a survey“
  • 【Java基础-27】Java中的访问修饰符:分类、作用及应用场景
  • Redis+注解实现限流机制(IP、自定义等)
  • SAP从入门到放弃系列之委外分包(Subcontracting)-Part1
  • nlp新词发现——浅析 TF·IDF
  • WebGL2示例项目常见问题解决方案
  • 鸿蒙元服务从0到上架【第三篇】(第二招有捷径)
  • Jimureport h2命令执行分析记录
  • vue 集成 webrtc-streamer 播放视频流 - 解决阿里云内外网访问视频流问题
  • 进网许可认证、交换路由设备检测项目更新25年1月起
  • Provides transitive vulnerable dependency maven 提示依赖存在漏洞问题的解决方法
  • WebAuthn 项目常见问题解决方案
  • LeetCode 844. 比较含退格的字符串 (C++实现)
  • Python8-写一些小作业
  • C++ STL vector基本原理和用法
  • 【计算机视觉基础CV-图像分类】05 - 深入解析ResNet与GoogLeNet:从基础理论到实际应用
  • 【人工智能-初级】基于用户的协同过滤推荐算法
  • 如何识别钓鱼邮件和诈骗网站?(附网络安全意识培训PPT资料)
  • Rust 在前端基建中的使用
  • 【人工智能】基于Python和OpenCV实现实时人脸识别系统:从基础到应用
  • Python 自动化 打开网站 填表登陆 例子
  • 【Chrome】浏览器提示警告Chrome is moving towards a new experience
  • 网络下载ts流媒体
  • iDP3复现代码模型训练全流程(一)——train_policy.sh
  • 重温设计模式--单例模式
  • 【人工智能】Python中的机器学习管道:如何用scikit-learn构建高效的ML管道
  • Redis存在安全漏洞
  • Scala图书管理系统
  • 【数据可视化案列】白葡萄酒质量数据的EDA可视化分析