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

news2024/11/25 0:29:36

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

        前面已经学习了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数据

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2063750.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

react 的学习随记

npx create-react-app my-app 创建一个名叫my-app的react的项目 npm run eject 运行 显示config 文件夹 react jsx (使用时将babel 将jsx转为js) 单页面时需要引用 1,样式(在虚拟dom时) 1. 引用样式时 用classNa…

(第三十三天)

1. 设置主从从 mysql57 服务器 ( 1 )配置主数据库 [rootmsater_5 ~] # systemctl stop filewalld [rootmsater_5 ~] # setenforce 0 [rootmsater_5 ~] # systemctl disable filewalld [rootmsater_5 ~] # ls anaconda-ks.cfg mysql-5.7.44-linux-g…

解决STM32使用J-Link可以擦除和读取但是无法烧录问题

现象 使用J-Link烧录模组固件,出现可以读取和擦除,但是无法烧录问题,提示错误如下: ERROR: Programming failed address 0x08000080 (program error)End of flash programmingERROR: Program failed 读出来的时候这个地址数据…

AWS EC2:助力中国企业扬帆出海

在全球化的今天,中国的企业家们正积极寻找机会走向世界舞台。在这个过程中,云计算成为了不可或缺的技术支撑。亚马逊AWS作为全球领先的云服务提供商,其EC2(Elastic Compute Cloud)弹性云服务器以其卓越的性能和广泛的基…

【学习笔记】灰色预测 GM(1,1) 模型 —— Matlab

文章目录 前言一、灰色预测模型灰色预测适用情况GM (1,1)模型 二、示例指数规律检验(原始数据级比检验)级比检验的定义GM(1,1) 模型的级比检验 模型求解求解微分方程 模型评价(检验模型对原始数据的拟合程度)残差检验级比偏差检验 三、代码实现----Matlab级比检验代码模型求解代…

jmeter中添加断言,使用包括匹配模式显示失败

1、在jmeter中为某个接口添加断言,测试模式中检查文本内容比较长时且模式匹配规则选择包括时则在运行时会提示失败,实际接口已经正确返回数据了。 2、这种情况下失败是因为测试模块中的检查文本内容过长,不应该在模式匹配规则中选择包括&…

“由于找不到msvcr110.dll无法继续执行”错误提示?msvcr110.dll在电脑中处于什么位置?

“由于找不到msvcr110.dll无法继续执行”的错误提示,是许多用户在使用基于Microsoft Visual C开发的应用程序时可能遇到的一个典型问题。这条错误消息指出系统缺少一个关键的动态链接库文件(DLL),即 msvcr110.dll,这是…

融资管理系统项目

系列文章目录 第一章 基础知识、数据类型学习 第二章 万年历项目 第三章 代码逻辑训练习题 第四章 方法、数组学习 第五章 图书管理系统项目 第六章 面向对象编程:封装、继承、多态学习 第七章 封装继承多态习题 第八章 常用类、包装类、异常处理机制学习 第九章 集…

SpringBoot框架如何实现上传与下载查看文件

基于SpringBoot框架,如何实现文件的上传与下载查看 提要 本项目借鉴于spring-guides/gs-uploading-files: Uploading Files :: Learn how to build a Spring application that accepts multi-part file uploads. (github.com)SpringBoot官网学习文档关于如何下载文…

Git基础学习(一)

文章目录 一. Git1. 定义2. SVN与Git的的区别 一. Git 1. 定义 Git 是一种分布式版本控制系统,用于管理软件项目的源代码。它是由 Linux 之父 Linus Torvalds 开发的,并已经成为了现代软件开发领域中最流行的版本控制系统之一。 使用 Git 可以追踪代码…

旅游管理系统

TOC springboot0748旅游管理系统 第1章 绪论 1.1课题背景 计算机的普及和互联网时代的到来使信息的发布和传播更加方便快捷。用户可以通过计算机上的浏览器访问多个应用系统,从中获取一些可以满足用户需求的管理系统。网站系统有时更像是一个大型“展示平台”&a…

基于SpringBoot的家电销售展示平台--论文pf

TOC springboot514基于SpringBoot的家电销售展示平台--论文pf 第1章 绪论 1.1选题动因 当前的网络技术,软件技术等都具备成熟的理论基础,市场上也出现各种技术开发的软件,这些软件都被用于各个领域,包括生活和工作的领域。随着…

HTML+JS谁是卧底游戏

先说一句:一段时间没发文章,好多僵尸粉关注我,这CSDN😠 主要功能 玩家设置:在游戏开始前,输入总人数、卧底人数和白板人数。系统会自动计算出剩下的平民人数,并随机分配身份。 身份查看&#…

html+css+js实现登录界面设计

在现代网页设计中,创建一个功能齐全且用户友好的登录页面是至关重要的。本文将介绍如何使用 HTML 和 CSS 创建一个简单而有效的登录页面,包括验证码、记住密码选项及忘记密码链接。 1. HTML 结构 我们将从 HTML 代码开始,构建一个包含登录表…

【Google SEO】搜索引擎索引综合SEO指南

有没有想过网站是如何在搜索引擎上列出的,以及 Google、Bing 和其他公司如何在几秒钟内为我们提供大量信息? 这种闪电般快速性能的秘诀在于搜索索引。它可以与所有页面的庞大且完美有序的目录档案进行比较。进入索引意味着搜索引擎已经看到了你的页面&a…

机器学习——lightGBM(学习整理)

目录 一、认识lightGBM 1. 简单介绍 2. 主要特点 LightGBM 的缺点 3. 模型训练方式 (1)Training API (2)Scikit-learn API 二、相关函数参数 1. Training API 2. Scikit-learn API(重复只做补充)…

python requests 被屏蔽(已设置header和代理IP,解决浏览器指纹问题)

情况说明: 已设置 User-Agent已使用代理IP之前请求没问题,突然无法请求了。我用浏览器打开网站可以正常访问。 我遇到的原因: 目标网站/接口,能够通过JA3或者其他浏览器指纹信息,识别到你不是通过浏览器进行访问的。…

【解决】JS Uncaught RangeError: Invalid array length

【解决】JS Uncaught RangeError: Invalid array length 在JavaScript编程中,Uncaught RangeError: Invalid array length 是一个相对常见的错误,通常发生在处理数组时提供了无效的长度值。这个错误可能由多种原因引起,本文将深入探讨此错误的…

LCP167 两数之和II--输入有序数组[leetcode-5]

LCP167 两数之和II–输入有序数组 给你一个下标从 1 开始的整数数组 numbers &#xff0c;该数组已按 非递减顺序排列 &#xff0c;请你从数组中找出满足相加之和等于目标数 target 的两个数。如果设这两个数分别是 numbers[index1] 和 numbers[index2] &#xff0c;则 1 <…

Redis(day 2)

一、常用指令 哈希Hash kv模式不变&#xff0c;但v是一个键值对 &#xff08;1&#xff09;hset、hget命令用于为哈希表中的字段赋值 。 &#xff08;2&#xff09;hmset、hmget 同时将多个field-value对设置到哈希表中。会覆盖哈希表中已存在的字段。 &#xff08;3&…