批量添加PPT备注

我一直都觉得,用python高效办公,是件没必要的事。。。

但直到最近写课做PPT,做了80多页PPT,要把每一页PPT的备注粘贴进去时

我觉得,有什么关系呢,一页一页粘

但是粘到5页,我感觉ctl+c\v频率有点儿高

隐隐担心,腱鞘炎会不会出现

而且,我还不止是做这一个PPT,以后还要做几个PPT,每次都要这么粘?

毫无疑问,复制粘贴的手指头,会僵硬,我将不再是那个和平经营里优秀的我自己

所以,还是搞个批量导入PPT备注的小工具吧~~

python 复制代码
from pptx import Presentation
from docx import Document
"""
需要修改ppt_path和doc_path
"""
ppt_path = r'C:\Users\qwe\Desktop\AI课\MJ\直播第二周2+3\MJ直播_2_完整.pptx'
doc_path = r"C:\Users\qwe\Desktop\AI课\MJ\直播第二周2+3\2_直播讲稿.docx"
doc = Document(doc_path)
ppt = Presentation(ppt_path)
# 处理文本
paras = []
temp = ''
for i in doc.paragraphs:
    if len(i.text)==0:
        print(temp)
        paras.append(temp)
        temp = ''
    else:
        temp = temp + i.text
        temp = temp+'\n'
paras.append(temp)

# 判断页数与备注量是否对应
doc_lens = len(paras)
ppt_lens = len(ppt.slides)
if doc_lens!=ppt_lens:
    print(doc_lens)
    print(ppt_lens)
    print("文档注意:不要连续空两行、末尾和开头不要有空行")
    print("PPT注意:不要隐藏PPT")
    raise Exception("文档和ppt页数不匹配,请重新检查")

for index in range(ppt_lens):
    # 获取每页PPT备注对象
    slide = ppt.slides[index]
    notes_slide = slide.notes_slide
    text_frame = notes_slide.notes_text_frame
    # 获取对应备注内容
    para = paras[index]
    # 往PPT里写入备注
    text_frame.text = para

new_ppt_name = ppt_path.split('.')[0]+'_备注.pptx'
ppt.save(new_ppt_name)
print(f"ppt备注已添加完成,保存在:{new_ppt_name}")
相关推荐
jieyucx3 小时前
Go语言深度解剖:Map扩容机制全解析(增量扩容+等量扩容+渐进式迁移)
开发语言·后端·golang·map·扩容策略
YJlio3 小时前
7.4.5 Windows 11 企业网络连接与网络重置实战:远程访问、本地策略与故障恢复
前端·chrome·windows·python·edge·机器人·django
脏脏a3 小时前
【C++模版】泛型编程:代码复用的终极利器
开发语言·c++·c++模版
island13143 小时前
【C++仿Muduo库#3】Server 服务器模块实现上
服务器·开发语言·c++
散峰而望3 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
小龙报3 小时前
【C语言】内存里的 “数字变形记”:整数三码、大小端与浮点数存储真相
c语言·开发语言·c++·创业创新·学习方法·visual studio
深耕AI3 小时前
【VS Code避坑指南】点击Python图标提示“没有Python环境”,选择安装uv后这堆输出到底是什么意思?
开发语言·python·uv
第一程序员3 小时前
Rust生命周期管理实战指南:从困惑到掌握
python·github
2301_789015623 小时前
C++:继承
c语言·开发语言·c++
程序员威哥3 小时前
实战!Python爬京东商品评论:从采集到情感分析+词云可视化,新手30分钟跑通
开发语言·爬虫·python·scrapy