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数据

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值