Python PPT合并与拆分 – 详解
目录
使用工具
Python 合并 PPT
合并多个PPT文档
合并每个PPT文档中的特定幻灯片
Python 拆分 PPT
按幻灯片数量拆分
按幻灯片范围拆分
按幻灯片内容拆分
按节 (Section) 拆分
在日常工作或学习中,我们经常需要对PPT文件进行调整,比如将多个PPT合并成一个,方便进行统一演示;或者将一个大型PPT拆分成多个小文件,便于团队协作或分类管理。对于经常需要合并或拆分PPT的人来说,使用代码自动执行此过程可以节省大量时间和精力。本博客将详细介绍如何使用 Python 自动化 PPT 合并和拆分的过程,包括以下内容:
- Python 合并 PPT
- 合并多个PPT文档
- 合并每个PPT文档中的特定幻灯片
- Python 拆分 PPT
- 按幻灯片数量拆分
- 按幻灯片范围拆分
- 按幻灯片内容拆分
- 按节 (Section) 拆分
使用工具
要在Python中实现PPT合并和拆分,可以使用 Spire.Presentation for Python库。该库主要用于在Python中创建、读取、修改和转换PowerPoint文件(包括.ppt和.pptx等格式)。
你可以通过以下命令安装此库:
pip install Spire.Presentation
Python 合并 PPT
合并PPT文件通常包括以下步骤:
- 打开每个待合并的PPT文档。
- 将这些PPT中的幻灯片复制到一个新的或指定的PPT中。
- 保存合并后的PPT文档。
下面将探讨两种常见的合并方法:合并多个PPT文档,以及合并每个PPT文档中的特定幻灯片。
合并多个PPT文档
在将多个 PPT 合并为一个文件时,通常需要按照每个文件中幻灯片的顺序进行排列。以下代码展示了如何创建一个新的 PPT,并依次从给定列表里的每个 PPT 文件中复制幻灯片到新PPT:
from spire.presentation import *# 合并多个 PPT 到一个新的 PPT
def merge_presentations(presentation_files, output_file):# 创建一个新的 PPTmerged_presentation = Presentation()# 移除默认空白幻灯片merged_presentation.Slides.RemoveAt(0)for file in presentation_files:# 加载待合并的 PPTpresentation = Presentation()presentation.LoadFromFile(file) for slide in presentation.Slides:# 将幻灯片依次复制到新 PPT 中merged_presentation.Slides.AppendBySlide(slide)# 保存合并后的 PPTmerged_presentation.SaveToFile(output_file, FileFormat.Pptx2016)# 要合并的 PPT 文件列表
files_to_merge = ["ppt1.pptx", "ppt2.pptx", "ppt3.pptx"]
# 调用合并方法
merge_presentations(files_to_merge, "合并PPT.pptx")
合并每个PPT文档中的特定幻灯片
如果你只想合并每个 PPT 中的特定幻灯片,可以通过指定幻灯片的索引(从0开始)来实现。以下代码允许你通过 slide_indices 参数选择要从每个 PPT 中提取的幻灯片:
from spire.presentation import *# 合并多个 PPT 中指定的幻灯片到一个新的 PPT
def merge_selected_slides(presentation_files, slide_indices, output_file):# 创建一个新的 PPTmerged_presentation = Presentation()# 移除默认空白幻灯片merged_presentation.Slides.RemoveAt(0)for i, file in enumerate(presentation_files):# 加载待合并的 PPTpresentation = Presentation()presentation.LoadFromFile(file) for j, slide in enumerate(presentation.Slides):if j in slide_indices[i]:# 将选定的幻灯片复制到新 PPT 中merged_presentation.Slides.AppendBySlide(slide)# 保存合并后的 PPTmerged_presentation.SaveToFile(output_file, FileFormat.Pptx2016)# 要合并的 PPT 文件列表
files_to_merge = ["ppt1.pptx", "ppt2.pptx"]
# 要合并的幻灯片索引
slide_indices = [[0, 2], [1]]
# 调用合并方法
merge_selected_slides(files_to_merge, slide_indices, "合并幻灯片.pptx")
Python 拆分 PPT
拆分 PPT 文件通常包括以下步骤:
- 加载原始 PPT。
- 选择要提取的幻灯片。
- 将这些幻灯片保存为一个新 PPT。
下面我们将探讨四种常见的拆分方法:按幻灯片数量拆分、按幻灯片范围拆分、按幻灯片内容拆分,以及按节(Section)拆分。
按幻灯片数量拆分
将一个 PPT 拆分为多个小文件,每个文件包含指定数量的幻灯片,是管理大型 PPT 的常见需求。下面的代码允许你指定每个文件包含的幻灯片数量,从而将一个大型PPT文件拆分为多个小型 PPT:
from spire.presentation import *
import os# 按指定的幻灯片数量拆分 PPT
def split_presentation_by_chunks(input_file, slides_per_file, output_directory):# 打开原始 PPTpresentation = Presentation()presentation.LoadFromFile(input_file)# 获取 PPT 中的总幻灯片数total_slides = presentation.Slides.Count# 确保输出目录存在if not os.path.exists(output_directory):os.makedirs(output_directory)# 按指定的块大小(slides_per_file)迭代幻灯片for start in range(0, total_slides, slides_per_file):# 为当前块创建一个新的 PPTsplit_presentation = Presentation()# 移除新 PPT 中的默认空白幻灯片split_presentation.Slides.RemoveAt(0)# 将当前块范围内的幻灯片添加到新 PPTfor i in range(start, min(start + slides_per_file, total_slides)):split_presentation.Slides.AppendBySlide(presentation.Slides[i])# 保存新 PPT 到指定目录,文件名根据当前块的索引生成output_file = os.path.join(output_directory, f"部分_{start // slides_per_file + 1}.pptx")split_presentation.SaveToFile(output_file, FileFormat.Pptx2016)# 调用方法,将 PPT 按每 3 张幻灯片拆分为多个文件,并保存到指定目录
split_presentation_by_chunks("ppt1.pptx", 3, "输出文件夹/")
按幻灯片范围拆分
如果你需要提取特定范围的幻灯片,可以通过指定起始和结束幻灯片索引(从 0 开始)来创建新 PPT 文件。以下代码允许你提取指定范围内的幻灯片:
from spire.presentation import *# 提取PPT中特定范围的幻灯片并保存为新文件
def split_presentation_by_range(input_file, start_slide, end_slide, output_file):# 打开原始PPTpresentation = Presentation()presentation.LoadFromFile(input_file)# 创建一个新PPTsplit_presentation = Presentation()# 移除新PPT中的默认空白幻灯片split_presentation.Slides.RemoveAt(0)# 将指定范围内的幻灯片添加到新PPTfor i in range(start_slide, end_slide + 1):split_presentation.Slides.AppendBySlide(presentation.Slides[i])# 保存新PPTsplit_presentation.SaveToFile(output_file, FileFormat.Pptx2016)# 调用方法,从PPT中提取第3 - 6张幻灯片并保存为新文件
split_presentation_by_range("ppt1.pptx", 2, 5, "按幻灯片范围拆分.pptx")
按幻灯片内容拆分
有时,你可能需要根据特定关键字或短语拆分 PPT。此方法可以提取包含特定内容的幻灯片,便于整理相关信息。以下代码会扫描每张幻灯片中的文本,如果找到指定关键字,则将该幻灯片添加到新 PPT 中:
from spire.presentation import *# 提取包含特定关键字的幻灯片到新PPT中
def split_by_content(input_file, keyword, output_file):# 打开原始PPTpresentation = Presentation()presentation.LoadFromFile(input_file)# 创建一个新的PPTsplit_presentation = Presentation()# 移除新PPT中的默认空白幻灯片split_presentation.Slides.RemoveAt(0)# 遍历原始PPT中的每张幻灯片for slide in presentation.Slides:# 检查幻灯片中的每个形状是否包含文本for shape in slide.Shapes:# 确保形状是AutoShape并具有文本框if isinstance(shape, IAutoShape) and shape.TextFrame is not None:# 检查文本中是否包含关键字if keyword in shape.TextFrame.Text:# 如果找到关键字,将幻灯片添加到新PPT中split_presentation.Slides.AppendBySlide(slide)break # 保存新PPTsplit_presentation.SaveToFile(output_file, FileFormat.Pptx2016)# 调用方法,将包含"科技"关键字的幻灯片提取到新PPT中
split_by_content("示例.pptx", "科技", "按幻灯片内容拆分.pptx")
按节 (Section) 拆分
在某些情况下,PPT 文档被分成多个节,每个节包含相关的幻灯片。按节拆分可以帮助我们将每个节中的幻灯片提取并保存为独立的 PPT 文件。以下代码展示了如何遍历每个节,并将其保存为单独的 PPT 文件:
from spire.presentation import *
import osdef split_presentation_by_section(input_file, output_directory):# 打开原始 PPTpresentation = Presentation()presentation.LoadFromFile(input_file)# 确保输出目录存在if not os.path.exists(output_directory):os.makedirs(output_directory)# 遍历所有节for i in range(presentation.SectionList.Count):# 获取当前节section = presentation.SectionList[i]# 创建新的 PPT new_presentation = Presentation()# 移除默认的空白幻灯片new_presentation.Slides.RemoveAt(0)# 添加节到新PPTnew_section = new_presentation.SectionList.Append(section.Name)# 获取当前节的幻灯片slides = section.GetSlides()# 将每个幻灯片插入到新的节中for slide_index, slide in enumerate(slides):new_section.Insert(slide_index, slide)# 保存新PPToutput_file = f"{output_directory}Section-{i + 1}.pptx"new_presentation.SaveToFile(output_file, FileFormat.Pptx2019) # 调用方法,按节拆分 PPT
split_presentation_by_section("节.pptx", "输出文件夹/")
以上就是使用 Python 实现 PPT 合并和拆分的全部内容,感谢阅读!
相关文章:
Python PPT合并与拆分 – 详解
目录 使用工具 Python 合并 PPT 合并多个PPT文档 合并每个PPT文档中的特定幻灯片 Python 拆分 PPT 按幻灯片数量拆分 按幻灯片范围拆分 按幻灯片内容拆分 按节 (Section) 拆分 在日常工作或学习中,我们经常需要对PPT文件进行调整,比如将多个PPT…...

舌头分割数据集labelme格式2557张1类别
数据集格式:labelme格式(不包含mask文件,仅仅包含jpg图片和对应的json文件) 图片数量(jpg文件个数):2557 标注数量(json文件个数):2557 标注类别数:1 标注类别名称:["tongue"] 每个类别标注的框数࿱…...
LVS能否实现两台服务器的负载均衡
LVS能否实现两台服务器的负载均衡 是的,LVS(Linux Virtual Server)可以实现两台服务器的负载均衡,并且它非常适合这种场景。 LVS(Linux Virtual Server)简介: LVS 是一种基于 Linux 的负载均…...
onlyoffice 容器配置修改后制作镜像导出以及上传到 dockerhub
1.将容器制作成新的镜像 docker commit -p -a "xxx" -m "zh-cn-20-100" onlyoffice ooffice:7.1.1.23docker commit: 这是 Docker 中用于创建新镜像的命令。 -p: 这个选项用于在提交之前暂停容器的运行。这可以确保数据的完整性,因为容器在提交…...

Java常用 Date 时间格式化、Calender日历、正则表达式的用法
目录 1. SimpleDateFormat 日期格式化类 1.1 Date 类型转 String 1.2 String 类型转 Date 2. Calendar 日历类 3. 正则表达式 3.1 正则表达式的组成部分 3.2 手机号正则表达式 3.3 常用密码校验正则表达式 1. SimpleDateFormat 日期格式化类 SimpleDateFormat 是Java中…...
案例讲解自然语言处理(NLP)
自然语言处理(NLP)是一种涉及计算机与人类自然语言之间的交互的技术。以下是一些NLP技术的示例: 语言翻译:NLP可以用于将一种语言翻译成另一种语言。Google翻译就是一个使用NLP技术的例子,它可以将输入的文本从一种语言…...

tryhackme——Pre Security(安检前)-Offensive Security(进攻性安全)
这里我用的edge的插件闪击翻译。这里我英语不好,所以用这个可以顺便学习下英语。 任务一:What is Offensive Security?(什么是进攻性安全?) 很简单啊,通过阅读,知道以下哪个选项更能代表您模拟黑客操作…...
2.python变量
理解,我将提供更详细和深入的解释,包括一些进阶概念和实际应用的例子。我们将从变量类型开始,逐步深入到每种数据类型的特性、操作方法以及它们在编程中的应用场景。 文章目录 1. 变量赋值与作用域变量赋值变量作用域 2. 标准数据类型Number…...

【工业机器视觉】基于深度学习的水表盘读数识别(4-训练与预测)
【工业机器视觉】基于深度学习的仪表盘识读(读数识别)(3)-CSDN博客 训练与预测 Ultralytics YOLO指的是由Ultralytics公司开发的一系列基于YOLO(You Only Look Once)架构的目标检测算法。YOLO是一种实时目标检测系统,它…...
opencv获取摄像头的最大分辨率图像
事情是这样的,在拼多多花了40买了一个4k高清的摄像偷,确实清楚。但是我一直以为网络摄像头分辨率只有640*480,于是用python测试了一下,上代码 import cv2def get_max_resolution(camera_index):"""获取摄像头的最大分辨率。&…...

23.DDD与微服务
学习视频来源:DDD独家秘籍视频合集 https://space.bilibili.com/24690212/channel/collectiondetail?sid1940048&ctype0 文章目录 DDD与微服务的关系1. DDD可以用微服务实现,也可以不用微服务实现2. DDD是微服务拆分的必须参考项之一3. 微服务架构…...

Redis是什么?Redis和MongoDB的区别在那里?
Redis介绍 Redis(Remote Dictionary Server)是一个开源的、基于内存的数据结构存储系统,它可以用作数据库、缓存和消息中间件。以下是关于Redis的详细介绍: 一、数据结构支持 字符串(String) 这是Redis最…...
git SSL certificate problem: unable to get local issuer certificate
Git 客户端将会验证服务器端提供的SSL证书是否由受信任的证书颁发机构(Certification Authority,CA)签发。如果Git客户端无法找到或验证本地签发者证书,就会出现 unable to get local issuer certificate 或类似的错误。 该问题一…...

使用Keil V6编译 FreeRTOS CMSIS V2版本 ETH + Lwip 编译报错问题解决方式
网上其他人写的都解决不了,要不用的是CMSIS V1版本,根据他们的方式搞完还是报错,今天花点时间自己搞一下。 不想自己动手?没问题,模版已上传Gitee https://gitee.com/maybe_404/stm32-f4xx_-free-rtos_-lwip_-templa…...

驱动开发系列30 - Linux Graphics DRM光标绘制分析
一:概述 本文分析了 Linux 直接渲染管理器 (DRM) 绘制光标的过程,目的是将 OpenGL 与 DRM 连接,弄清楚整个调用逻辑。本文将详细描述这一过程,介绍如何在图形软件栈中实现光标渲染。整体软件栈的架构图也将展示其中的各个组成部分及其相互关系。 二:代码介绍 drm-cursor …...
如何利用Java爬虫获得淘宝买家秀
在电商平台上,买家秀数据是商家了解消费者反馈、优化产品和服务的重要资源。本文将详细介绍如何利用Java爬虫技术获取淘宝商品的买家秀信息,并提供一个完整的代码示例。 一、淘宝买家秀数据的重要性 买家秀数据包括买家上传的图片、视频、评论等内容&a…...

【ArcGIS】基于R语言、MaxEnt模型融合技术的物种分布模拟、参数优化方法、结果分析制图与论文写作
第一章、以问题导入的方式,深入掌握原理基础【理论篇】 1、R语言入门: (1)安装R及集成开发环境(IDE);(2)R语言基础语法与数据结构,包括:程序包安…...
虚幻引擎C++按键绑定
在项目的 Project Settings -> Engine -> Input 中进行配置。 配置输入映射的步骤: 打开 Project Settings: 在 Unreal Editor 中,点击菜单栏的 Edit -> Project Settings。 导航到 Input: 在 Project Settings 窗口的左侧导航栏中࿰…...
秒杀抢购场景下实战JVM级别锁与分布式锁
背景历史 在电商系统中,秒杀抢购活动是一种常见的营销手段。它通过设定极低的价格和有限的商品数量,吸引大量用户在特定时间点抢购,从而迅速增加销量、提升品牌曝光度和用户活跃度。然而,这种活动也对系统的性能和稳定性提出了极…...
【Pandas】pandas interval_range
Pandas2.2 General Top-level dealing with Interval data 方法描述interval_range([start, end, periods, freq, …])用于生成固定长度的区间序列 pandas.interval_range() pandas.interval_range() 是 Pandas 库中用于生成固定频率的 Interval 对象的函数。这些 Interval…...

多云管理“拦路虎”:深入解析网络互联、身份同步与成本可视化的技术复杂度
一、引言:多云环境的技术复杂性本质 企业采用多云策略已从技术选型升维至生存刚需。当业务系统分散部署在多个云平台时,基础设施的技术债呈现指数级积累。网络连接、身份认证、成本管理这三大核心挑战相互嵌套:跨云网络构建数据…...
【解密LSTM、GRU如何解决传统RNN梯度消失问题】
解密LSTM与GRU:如何让RNN变得更聪明? 在深度学习的世界里,循环神经网络(RNN)以其卓越的序列数据处理能力广泛应用于自然语言处理、时间序列预测等领域。然而,传统RNN存在的一个严重问题——梯度消失&#…...
2024年赣州旅游投资集团社会招聘笔试真
2024年赣州旅游投资集团社会招聘笔试真 题 ( 满 分 1 0 0 分 时 间 1 2 0 分 钟 ) 一、单选题(每题只有一个正确答案,答错、不答或多答均不得分) 1.纪要的特点不包括()。 A.概括重点 B.指导传达 C. 客观纪实 D.有言必录 【答案】: D 2.1864年,()预言了电磁波的存在,并指出…...

linux arm系统烧录
1、打开瑞芯微程序 2、按住linux arm 的 recover按键 插入电源 3、当瑞芯微检测到有设备 4、松开recover按键 5、选择升级固件 6、点击固件选择本地刷机的linux arm 镜像 7、点击升级 (忘了有没有这步了 估计有) 刷机程序 和 镜像 就不提供了。要刷的时…...

Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决
Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决 问题背景 在一个基于 Spring Cloud Gateway WebFlux 构建的微服务项目中,新增了一个本地验证码接口 /code,使用函数式路由(RouterFunction)和 Hutool 的 Circle…...
iOS性能调优实战:借助克魔(KeyMob)与常用工具深度洞察App瓶颈
在日常iOS开发过程中,性能问题往往是最令人头疼的一类Bug。尤其是在App上线前的压测阶段或是处理用户反馈的高发期,开发者往往需要面对卡顿、崩溃、能耗异常、日志混乱等一系列问题。这些问题表面上看似偶发,但背后往往隐藏着系统资源调度不当…...

人工智能(大型语言模型 LLMs)对不同学科的影响以及由此产生的新学习方式
今天是关于AI如何在教学中增强学生的学习体验,我把重要信息标红了。人文学科的价值被低估了 ⬇️ 转型与必要性 人工智能正在深刻地改变教育,这并非炒作,而是已经发生的巨大变革。教育机构和教育者不能忽视它,试图简单地禁止学生使…...

在Mathematica中实现Newton-Raphson迭代的收敛时间算法(一般三次多项式)
考察一般的三次多项式,以r为参数: p[z_, r_] : z^3 (r - 1) z - r; roots[r_] : z /. Solve[p[z, r] 0, z]; 此多项式的根为: 尽管看起来这个多项式是特殊的,其实一般的三次多项式都是可以通过线性变换化为这个形式…...

宇树科技,改名了!
提到国内具身智能和机器人领域的代表企业,那宇树科技(Unitree)必须名列其榜。 最近,宇树科技的一项新变动消息在业界引发了不少关注和讨论,即: 宇树向其合作伙伴发布了一封公司名称变更函称,因…...

实战三:开发网页端界面完成黑白视频转为彩色视频
一、需求描述 设计一个简单的视频上色应用,用户可以通过网页界面上传黑白视频,系统会自动将其转换为彩色视频。整个过程对用户来说非常简单直观,不需要了解技术细节。 效果图 二、实现思路 总体思路: 用户通过Gradio界面上…...