Python办公自动化 python-pptx模块的安装与使用【1】

2024-08-23 01:28

本文主要是介绍Python办公自动化 python-pptx模块的安装与使用【1】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

学好办公自动化,走遍天下都不怕!!

        前面已经学习了python自动处理Excel数据和自动生成word试卷的案例, 今天学习一下python中的python-pptx模块,主要用于自动化生成和更新PPT文件。主要是python-pptx的用法,方便自己以后查看,也欢迎正在学习python的小伙伴参考,有问题请请评论区留言指正,大家共同学习,共同进步,感谢。

目录

一、安装

二、python-pptx模块的用法

2.1 创建ppt文件对象 

2.2 添加内容

 2.3 保存文档

三、总结


一、安装

在使用之前需要先安装导入模块。安装命令:pip install python-pptx

# 安装依赖
pip install python-pptx#导入模块
import pptx

二、python-pptx模块的用法

python-pptx也是python的第三方模块。主要分为三个步骤:1创建ppt文件对象 2.向文件中填充内容 3.保存文稿文件。

所有需要用到的包都直接写在这里了 。

import pptx
# 设置距离宽度
from pptx.util import Inches,Pt
# 添加图形
from pptx.enum.shapes import MSO_SHAPE
# 填充颜色
from pptx.dml.color import RGBColor
#导入写入图表用的包
from pptx.chart.data import CategoryChartData
from pptx.enum.chart import XL_CHART_TYPE
# 设置图例需要
from pptx.enum.chart import XL_LEGEND_POSITION
2.1 创建ppt文件对象 
#1.新建ppt对象
ppts = pptx.Presentation()
2.2 添加内容

添加幻灯片,其中slide_layouts[0]是从幻灯片模板中根据index值去选择合适的模板,0表示第一个模板,如下图所示:

#slide_layouts[0] 是指新建幻灯片序列选择类型
slide = ppts.slides.add_slide(ppts.slide_layouts[0]) # 删除幻灯片
#del ppts.slides._sldIdLst[1] # 删除第二张幻灯片

 向幻灯片中添加文本内容。包括幻灯片标题、副标题、段落文本追加文本。

# 向幻灯片添加文本
text1 = slide.shapes.add_textbox(Inches(5),Inches(5),Inches(5),Inches(5))
text1.text = "这是新添加的文本框"
p1 = text1.text_frame.add_paragraph()
# 添加段落
p1.text = "这是新添加的文本"
p1.add_run().text = '这是继续追加的文本 谢谢'#设置标题
title_shapes = slide.shapes.title
title_shapes.text = '标题1'
# 副标题
slide.shapes.placeholders[1].text='副标题'

 

向ppt幻灯片中插入添加自选图形,下面代码是插入自选的图形,并且设置了填充颜色和边框的颜色,以及边框的粗细大小。图形自选点开 add_shapes()方法里面找到对应的变量参数传进去就好了,向下面代码一样。

#ppt 插入图形
#添加自选图形
shape = slide1.shapes.add_shape(MSO_SHAPE.FUNNEL,Inches(2),Inches(2),Inches(5),Inches(3)) #添加六边形 图形可以去文档中查找
# 图形填充 和边框样式
fill = shape.fill
fill.solid()
fill.fore_color.rgb = RGBColor(255,228,188)
line = shape.line
line.color.rgb = RGBColor(255,165,0)
line.width = Pt(5)

 

 向ppt幻灯片中插入表格table,可以设置表格的行数列数以及单元格合并、取消单元格合并。

# 参数 表格的行数、列数,距离左侧的距离、右侧的距离、表格的宽度、表格的高度
table = slide1.shapes.add_table(3,3,Inches(2),Inches(2),Inches(5),Inches(3)).table 
table.cell(1,0).text = '房型大小'
table.cell(1,1).text = '单价'
table.cell(1,2).text = '附近商圈'
table.cell(2,0).text = '98'
table.cell(2,1).text = '52'
table.cell(2,2).text = '大型超市'#合并单元格 
cell = table.cell(0,0)
cell1 = table.cell(0,2)
cell.merge(cell1)
#cell.split() # 取消合并
table.cell(0,0).text = '房屋信息表'
print(cell.is_merge_origin) # 判断单元格是否合并 true

 

 #写入图表到ppt,可以向幻灯片中添加图表:柱状图、折线图、饼图等。

#写入图表到ppt
chart_data = CategoryChartData()
chart_data.categories = ['65户型','89户型','107户型'] # x轴的数据
chart_data.add_series('Y2023',(100,200,300))
chart_data.add_series('Y2024',(50,50,100))#line 折线图COLUMN_CLUSTERED柱状图
chart = slide.shapes.add_chart(XL_CHART_TYPE.COLUMN_CLUSTERED,Inches(2),Inches(2),Inches(6),Inches(4),chart_data).chart  
chart.has_title = True
chart.chart_title.text_frame.text='房屋销售情况' #图表标题
chart.has_legend = True
chart.legend.position = XL_LEGEND_POSITION.RIGHT

 2.3 保存文档
#3.保存文稿
ppts.save('pptdemo.pptx')# 如果要保存成新的文档 直接在save方法中设置新文档的名称
# 比如 ppts.save('newppt.pptx')

三、总结

  1. python-pptx第三方模块的介绍以及安装 pip install python-pptx
  2. 模块的用法 主要分为三步:新建文件对象、添加内容、保存文档
  3. 添加内容又分为添加文本、表格、自选图形以及图标、如何删除幻灯片、合并取消合并单元格等
  4. 最后记得保存文档以及如何保存新的文档。

案例:房产购房者分析报告。

相关内容:

python运行环境搭建 | python爬虫获取数据 | python自动化之word篇 | python处理excel数据

这篇关于Python办公自动化 python-pptx模块的安装与使用【1】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097954

相关文章

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核