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

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

python获取网页表格的多种方法汇总

《python获取网页表格的多种方法汇总》我们在网页上看到很多的表格,如果要获取里面的数据或者转化成其他格式,就需要将表格获取下来并进行整理,在Python中,获取网页表格的方法有多种,下面就跟随小编... 目录1. 使用Pandas的read_html2. 使用BeautifulSoup和pandas3.

Pandas透视表(Pivot Table)的具体使用

《Pandas透视表(PivotTable)的具体使用》透视表用于在数据分析和处理过程中进行数据重塑和汇总,本文就来介绍一下Pandas透视表(PivotTable)的具体使用,感兴趣的可以了解一下... 目录前言什么是透视表?使用步骤1. 引入必要的库2. 读取数据3. 创建透视表4. 查看透视表总结前言

Python装饰器之类装饰器详解

《Python装饰器之类装饰器详解》本文将详细介绍Python中类装饰器的概念、使用方法以及应用场景,并通过一个综合详细的例子展示如何使用类装饰器,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. 引言2. 装饰器的基本概念2.1. 函数装饰器复习2.2 类装饰器的定义和使用3. 类装饰

Python 交互式可视化的利器Bokeh的使用

《Python交互式可视化的利器Bokeh的使用》Bokeh是一个专注于Web端交互式数据可视化的Python库,本文主要介绍了Python交互式可视化的利器Bokeh的使用,具有一定的参考价值,感... 目录1. Bokeh 简介1.1 为什么选择 Bokeh1.2 安装与环境配置2. Bokeh 基础2

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读