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如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详