小猪的Python学习之旅 —— 22.安静!吵到我用TNT了(上)

简介: 原理利用Python-pptx库,通过编写模板的方式自动生成批量PPT!

引言:


批量生成简单PPT的套路,我觉得思路无非这样:


根据情形,定义几套模板,然后约定一个规则,根据不同的内容调用不同的模板,进行内容填充。


套路知道了,接下来就是看看Python有没有支持库了~ 找到两个pptxwin32com,本节只用前者,因为后者的文档是真的 看得人头皮发麻,而且网上的例子非常少...


1.python-pptx库


官方文档python-pptx.readthedocs.io/en/latest/i…官方仓库

github.com/scanny/pyth…安装库pip install python-pptx


对了,因为win32com那个库要调用微软的PowerPoint,我把电脑重装回 Win 10了,索性安装了最新版的PyCharm,然后发现创建的工程和以前 创建的工程结构不一样,多了个这样的东西:



终端运行也变成了:(venv) F:\Python> 这样,这个就是虚拟环境, 简单点说就是对开发环境进行隔离,比如你这个项目基于Python 2.x,另一个项目 基于Python 3.x,或者说着两个项目里依赖的同一个模块用着不同的版本,通过 虚拟环境可以让这两个项目互不干扰,将所需的包安装到独立的环境中。


Python中常用的创建和管理虚拟环境的工具有:virtualenvpyvenv, Pycharm默认带有virtualenv,新建的时候就可以看到,具体怎么定制化, 自行百度吧~对了,下载模块都在**Lib/site-packages**目录下!



2.实现流程分析


首先的话,先想想有哪些模板,罗列下:


  • 1.只有一张图片


  • 2.只有一条文字


  • 3.一条文字和一张图片


  • 4.两条文字


  • 5.四条文字


然后布局大概这样咯:



接着定义一个规则,数据怎么传,这里采用最简单的套路,写个txt文件, 每行代表一个PPT,参数通过逗号间隔,于是完整的PPT对应这样的txt文件:



通过逗号分割参数,优先判断是否有图片,有的话走模板1,3, 其他再另外判断。好的,思路有了,接下来开始一步步实现吧。


3.代码实现



1.定义一个厘米转英寸的方法


以为PPT里的位置和大小用到的单位都是厘米,需要转换下


# 厘米转英寸
def cm_to_in(cm):
    return Inches(cm / 2.54)


2.编写模板


先是模板1,传入Presentation的对象,这个你可以理解成PPT对象, 调用该对象的**.slides.add_slide()方法添加一张幻灯片,pptx库为我们 提供了八个不一样的模板,喜欢的可以自己一个个试,这里我们直接用第七 张空白幻灯片**,下标从0开始,所以是**prs.slide_layouts[6],幻灯片 加了之后,调用Presentation的save(ppt文件名)**函数打开生成的PPT, 然后点击设置 -> 幻灯片大小 -> 直接选择16:9或者设置幻灯片大小,比如我 的,这里的宽度和高度就是我们幻灯片的大小了,后面填充满屏的图片就要 用到这个。



然后调用add_picture函数添加一个满屏图片:


slide.shapes.add_picture(ppt_bg_path, cm_to_in(0), cm_to_in(0), cm_to_in(25.4), cm_to_in(14.288))


然后模板1就写完了,完成代码如下:


# 模板1:只有一张图片
def model_1(prs, pic_path):
    slide = prs.slides.add_slide(prs.slide_layouts[6])
    slide.shapes.add_picture(pic_path, cm_to_in(0), cm_to_in(0), cm_to_in(25.4), cm_to_in(14.288))
# 调用:
presentation = Presentation(ppt_file_name)
model_1(presentation, laoluo_bg_path)


打开生成的ppt:



哟,成功生成,接着到模板2:


填充满屏图片,然后新建一个文本框:


title_box = slide.shapes.add_textbox(cm_to_in(3.89), cm_to_in(5.35), cm_to_in(17.61), cm_to_in(3.59))


再接着添加一个文本域:


paragraph = title_box.text_frame.add_paragraph()


然后就可以对文本域里进行文字相关的操作了:


paragraph.text = title  # 设置文本
    paragraph.vertical_anchor = MSO_VERTICAL_ANCHOR.MIDDLE  # 设置垂直方向对齐方式
    paragraph.alignment = PP_PARAGRAPH_ALIGNMENT.CENTER # 设置水平方向对齐方式
    paragraph.font.size = Pt(60)    # 设置文本大小,PT代表磅
    paragraph.font.name = '微软雅黑'    # 设置字体
    paragraph.font.color.rgb = RGBColor(255, 255, 255)  # 设置字体颜色


相关文章
|
1天前
|
Python
python pandas学习(一)
该代码段展示了四个主要操作:1) 删除指定列名,如商品id;2) 使用正则表达式模糊匹配并删除列,例如匹配订单商品名称1的列;3) 将毫秒级时间戳转换为带有时区调整的日期时间格式,并增加8小时以适应本地时区;4) 将列表转换为DataFrame后保存为Excel文件,文件路径和名称根据变量拼接而成。
12 3
|
2月前
|
Python 容器
Python学习的自我理解和想法(9)
这是我在B站跟随千锋教育学习Python的第9天,主要学习了赋值、浅拷贝和深拷贝的概念及其底层逻辑。由于开学时间紧张,内容较为简略,但希望能帮助理解这些重要概念。赋值是创建引用,浅拷贝创建新容器但元素仍引用原对象,深拷贝则创建完全独立的新对象。希望对大家有所帮助,欢迎讨论。
|
2月前
|
Python
Python学习的自我理解和想法(10)
这是我在千锋教育B站课程学习Python的第10天笔记,主要学习了函数的相关知识。内容包括函数的定义、组成、命名、参数分类(必须参数、关键字参数、默认参数、不定长参数)及调用注意事项。由于开学时间有限,记录较为简略,望谅解。通过学习,我理解了函数可以封装常用功能,简化代码并便于维护。若有不当之处,欢迎指正。
|
1月前
|
数据可视化 数据挖掘 大数据
1.1 学习Python操作Excel的必要性
学习Python操作Excel在当今数据驱动的商业环境中至关重要。Python能处理大规模数据集,突破Excel行数限制;提供丰富的库实现复杂数据分析和自动化任务,显著提高效率。掌握这项技能不仅能提升个人能力,还能为企业带来价值,减少人为错误,提高决策效率。推荐从基础语法、Excel操作库开始学习,逐步进阶到数据可视化和自动化报表系统。通过实际项目巩固知识,关注新技术,为职业发展奠定坚实基础。
|
2月前
|
存储 索引 Python
Python学习的自我理解和想法(6)
这是我在B站千锋教育学习Python的第6天笔记,主要学习了字典的使用方法,包括字典的基本概念、访问、修改、添加、删除元素,以及获取字典信息、遍历字典和合并字典等内容。开学后时间有限,内容较为简略,敬请谅解。
|
2月前
|
程序员 Python
Python学习的自我理解和想法(3)
这是学习Python第三天的内容总结,主要围绕字符串操作展开,包括字符串的提取、分割、合并、替换、判断、编码及格式化输出等,通过B站黑马程序员课程跟随老师实践,非原创代码。
|
2月前
|
Python
Python学习的自我理解和想法(7)
学的是b站的课程(千锋教育),跟老师写程序,不是自创的代码! 今天是学Python的第七天,学的内容是集合。开学了,时间不多,写得不多,见谅。
|
2月前
|
存储 安全 索引
Python学习的自我理解和想法(8)
这是我在B站千锋教育学习Python的第8天,主要内容是元组。元组是一种不可变的序列数据类型,用于存储一组有序的元素。本文介绍了元组的基本操作,包括创建、访问、合并、切片、遍历等,并总结了元组的主要特点,如不可变性、有序性和可作为字典的键。由于开学时间紧张,内容较为简略,望见谅。
|
2月前
|
存储 索引 Python
Python学习的自我理解和想法(4)
今天是学习Python的第四天,主要学习了列表。列表是一种可变序列类型,可以存储任意类型的元素,支持索引和切片操作,并且有丰富的内置方法。主要内容包括列表的入门、关键要点、遍历、合并、判断元素是否存在、切片、添加和删除元素等。通过这些知识点,可以更好地理解和应用列表这一强大的数据结构。
|
2月前
|
索引 Python
Python学习的自我理解和想法(5)
这是我在B站千锋教育学习Python的第五天笔记,主要内容包括列表的操作,如排序(`sort()`、``sorted()``)、翻转(`reverse()`)、获取长度(`len()`)、最大最小值(`max()`、``min()``)、索引(`index()`)、嵌套列表和列表生成(`range`、列表生成式)。通过这些操作,可以更高效地处理数据。希望对大家有所帮助!

热门文章

最新文章

推荐镜像

更多