python 办公自动化-生成ppt文本和图
最终样式

代码实现
# 可编辑折线+写入文字 成功
# 问题: 设置字体类型和加粗和字体为微软雅黑,是只改了字母和数字的字体,中文没变化 pip install pptx_ea_font 这个库可以解决这个问题
import pandas as pd
import pptx_ea_font
import matplotlib.pyplot as plt
from pptx import Presentation
from pptx.util import Inches,Pt,Cm
from pptx.chart.data import ChartData,CategoryChartData
from pptx.dml.color import RGBColor
from pptx.enum.chart import XL_CHART_TYPE,XL_LABEL_POSITION,XL_LEGEND_POSITION,XL_TICK_MARK
path='E:\\13 python 下侧双x轴折线图\\'
df = pd.read_excel(path+'双x轴测试数据1.xlsx', sheet_name='Sheet4') # 修改为你的文件名和工作表名#标题
tf_text='双x轴测试'
# 中间文本
tm_text='''测试情况:
问题设置字体加粗和微软雅黑,只改了字母和数字的字体,中文没变化''' # 三引号,自动换行
# 轴
td_text=' 2023年 2024年'
# 注释
tdd_text='''*注释
数据来源:胡编乱造
数据范围:1年有365个日出'''#轴字体
def zhou_font(tf,text_down):para = tf.add_paragraph() # 新增段落para.text = text_down # 向段落写入文字# para.alignment = PP_ALIGN.CENTER # 居中para.line_spacing = 1 # 1.5 倍的行距### 设置字体font = para.fontfont.name = '微软雅黑' # 字体类型font.bold = True # 加粗font.size = Pt(12) #下标注释字体
def text_downfont(tf,text_down):para = tf.add_paragraph() # 新增段落para.text = text_down # 向段落写入文字# para.alignment = PP_ALIGN.CENTER # 居中para.line_spacing = 1 # 1.5 倍的行距### 设置字体font = para.fontfont.name = '微软雅黑' # 字体类型font.bold = False # 加粗font.size = Pt(10) #正文字体
def text_font(tf,text_down):para = tf.add_paragraph() # 新增段落para.text = text_down # 向段落写入文字# para.alignment = PP_ALIGN.CENTER # 居中para.line_spacing = 1 # 1.5 倍的行距### 设置字体font = para.font# pptx_ea_font.set_font(run,new_font)font.name = '微软雅黑' # 字体类型font.bold = False # 加粗font.size = Pt(20) #标题字体
def text_titlefont(tf,text_down):para = tf.add_paragraph() # 新增段落para.text = text_down # 向段落写入文字# para.alignment = PP_ALIGN.CENTER # 居中para.line_spacing = 0 # 1.5 倍的行距### 设置字体font = para.fontfont.name = '微软雅黑' # 字体类型font.bold = True # 加粗font.size = Pt(24) font.color.rgb = RGBColor(192, 0, 0) # 设置颜色 红色 # 折线图样式
def line_chart_mod(chart):chart.has_legend = Truechart.legend.position = XL_LEGEND_POSITION.BOTTOM #图例chart.legend.font.size = Pt(12)chart.legend.font.bold = Truechart.legend.font.name = '微软雅黑'chart.show_value=True# x轴category_axis = chart.category_axiscategory_axis.has_major_gridlines = True# category_axis.minor_tick_mark = XL_TICK_MARK.OUTSIDE# category_axis.tick_labels.font.italic = False #斜体# category_axis.tick_labels.font.size = Pt(12)# tick_labels.number_format = '0"%"'tick_labels = category_axis.tick_labelstick_labels.font.bold = Truetick_labels.font.size = Pt(12)tick_labels.font.name = '微软雅黑'# y轴value_axis = chart.value_axisvalue_axis.maximum_scale = 120# value_axis.minor_tick_mark = XL_TICK_MARK.OUTSIDE value_axis.has_major_gridlines = Falsevalue_axis.has_minor_gridlines = Falsetick_labels = value_axis.tick_labels# tick_labels.number_format = '0"%"'tick_labels.font.bold = Truetick_labels.font.size = Pt(12)tick_labels.font.name = '微软雅黑'def paste_picture_content(path,df,tf_text,tm_text,td_text,tdd_text):prs = Presentation() blank_slide_layout = prs.slide_layouts[6] #选择模板中的空白页[6]slide = prs.slides.add_slide(blank_slide_layout) #新建空白页[6]###添加折线图shapes = slide.shapes# shapes.title.text = '双x轴折线图'# 准备数据chart_data = ChartData()chart_data.categories = df['月份'] chart_data.add_series('系列一', df['系列一']) #,number_format='0.0'轴展示数据形式chart_data.add_series('系列二', df['系列二'])# 在幻灯片中添加折线图x, y, cx, cy = Cm(0.25), Cm(6), Cm(24.78), Cm(8.2) #left, top, width, heightchart=slide.shapes.add_chart(XL_CHART_TYPE.LINE, x, y, cx, cy, chart_data).chartplot = chart.plots[0]plot.has_data_labels = Truedata_labels = plot.data_labelsdata_labels.font.size = Pt(9)# data_labels.font.color.rgb = RGBColor('','')data_labels.position = XL_LABEL_POSITION.INSIDE_END# 修改折线图样式chart=line_chart_mod(chart)# chart = chart.chart# left, top, width, height = Cm(0.25), Cm(5), Cm(24.78), Cm(5.6)# pic = slide.shapes.add_picture(path+'chart.png', left, top, width, height)###确定文本框在空白ppt中的位置,以及文本框在的大小;将文本框在贴到空白页中#标题left, top, width, height = Cm(0.61), Cm(0.5), Cm(10), Cm(1.28)tf = slide.shapes.add_textbox(left=left, top=top, width=width, height=height).text_frame# tf.font.color.rgb = RGBColor(192, 0, 0) # 字体颜色para = text_titlefont(tf,tf_text) # 中间文本left, top, width, height = Cm(1.7), Cm(2), Cm(8), Cm(0.5)tf = slide.shapes.add_textbox(left=left, top=top, width=width, height=height).text_frame# tf.text = tm_text para = text_font(tf,tm_text) #轴left, top, width, height = Cm(5), Cm(12), Cm(8), Cm(1)tf = slide.shapes.add_textbox(left=left, top=top, width=width, height=height).text_frame # 在指定位置添加文本框para = zhou_font(tf,td_text)# 注释left, top, width, height = Cm(0.03), Cm(16.1), Cm(18), Cm(1)tf = slide.shapes.add_textbox(left=left, top=top, width=width, height=height).text_frame# tf.paragraphs[0].text = tdd_text para = text_downfont(tf,tdd_text) prs.save(path+'line_chart05.pptx')
paste_picture_content(path,df,tf_text,tm_text,td_text,tdd_text)
参考:https://python-pptx.readthedocs.io/en/latest/user/charts.html#line-chart
# pip install python-pptx
相关文章:
python 办公自动化-生成ppt文本和图
最终样式 代码实现 # 可编辑折线写入文字 成功 # 问题: 设置字体类型和加粗和字体为微软雅黑,是只改了字母和数字的字体,中文没变化 pip install pptx_ea_font 这个库可以解决这个问题 import pandas as pd import pptx_ea_font import mat…...
「动态规划」买卖股票的最佳时机
力扣原题链接,点击跳转。 给定一个整数数组prices,prices[i]表示股票在第i天的价格。你最多完成2笔交易。你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。设计一个算法计算最大利润。 我们用动态规划的思想来解决…...
Java 并发编程面试二
目录 一、并发编程三要素? 二、实现可见性的方法有哪些? 三、多线程的价值? 四、创建线程的有哪些方式? 五、创建线程的三种方式的对比? 六、Java 线程具有五中基本状态 七、什么是线程池?有哪几种创建方式 八、四种线程池的创建 九、线程池的优点? 十、常用的…...
成功解决“ModuleNotFoundError: No Module Named ‘utils’”错误的全面指南
成功解决“ModuleNotFoundError: No Module Named ‘utils’”错误的全面指南 在Python编程中,遇到ModuleNotFoundError: No Module Named utils这样的错误通常意味着Python解释器无法找到名为utils的模块。这可能是由于多种原因造成的,比如模块确实不存…...
Nvidia Jetson/Orin +FPGA+AI大算力边缘计算盒子:公路智能巡检解决方案
项目背景 中国公路网络庞大,总里程超过535万公里,高速公路里程位居世界前列。面对基础设施存量的不断增长,公路养护管理已迈入“建管养并重”的新时代。随着养护支出的逐年攀升,如何提升养护效率、降低管理成本,成为亟…...
【Maxcompute】geohash转经纬度,经纬度转geohash,计算geohash九宫格
1.梳理、总结经纬度处理在Maxcompute平台上的实战应用,如geohash转经纬度,经纬度转geohash,计算geohash九宫格等。 2.欢迎批评指正,跪谢一键三连! 文章目录 1.部署代码1.部署代码 部署至Maxcompute(ODPS)-DataWorks平台,去掉代码注释即可#coding:utf-8 # from odps.udf…...
【R语言基础】如何更新R版本
文章目录 概要流程细节具体步骤 概要 提示:由于软件包的更新,所以需要更新R至新版本 流程细节 查看当前R版本 R.version下载更新包:installr install.packages("installr")library(installr)跟着向导一步步执行安装 具体步骤 …...
Python知识点10---函数
提前说一点:如果你是专注于Python开发,那么本系列知识点只是带你入个门再详细的开发点就要去看其他资料了,而如果你和作者一样只是操作其他技术的Python API那就足够了。 Python的函数和Scala的函数很像,语法很简单,注…...
有哪些挣钱软件一天能赚几十元?盘点十个能长期做下去的挣钱软件
在这个信息爆炸的时代,每个人都在寻找快速赚钱的秘诀。很多人做兼职副业的目标并不是获得很大的成功,大部分人一天能赚几十就心满意足了。 今天,我要带你一探究竟,揭秘那些能让你日赚几十元的挣钱软件。准备好了吗?让我…...
CentOS7安装MySQL教程
第一章 检查是否安装了Mysql 1.1 yum检查 yum list installed | grep mysql 1.2 安装则直接删除 yum remove xxx 1.3 rpm检查 rpm -qa | grep -i mysql # 有则直接删除 rpm -e --nodeps xxx 第二章 正式安装MySQL 2.1 yum安装,下载mysql wget --no-check-ce…...
师彼长技以助己(3)逻辑思维
师彼长技以助己(3)逻辑思维 前言 上一篇文章进行了工程思维和产品思维的测试,并介绍了几个比较重要的产品思维模型。接下来本篇介绍工程思维。(注意产品思维并不代表产品经理思维,工程思维也并不代表工程师思维&…...
LeetCode:反转链表I
文章收录于LeetCode专栏 LeetCode地址 反转链表I 题目 给你单链表的头节点head,请你反转链表,并返回反转后的链表。 示例 1: #mermaid-svg-IYmD16EKuu3CZWwV {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size…...
oracle linux7安装oracle11g0204
1、平时需要修改 /etc/redhat-release文件为Red Hat Enterprise Linux 7,这次不需要了。 2、关闭selinx nano /etc/selinux/config 改为disabled 3、nano /etc/hosts 修改解析 在oracle服务器中增加 /etc/hosts中一个对应 192.168.1.10 CLOUD-MC-SQL1 4、修改系统文件 /…...
STM32--ADC
一、简介 *ADC(Analog-Digital Converter)模拟-数字转换器 *ADC可以将引脚上连续变化的模拟电压转换为内存中存储的数字变量,建立模拟电路到数字电路的桥梁 *12位逐次逼近型ADC,1us转换时间 *输入电压范围:0~3.3V&…...
【TB作品】msp430f149单片机,读取ds18b20温度,显示到数码管,串口发送温度到电脑
功能 msp430f149单片机 读取ds18b20温度,显示到数码管,串口发送温度到电脑 部分程序 /************************************************* * 程序功能:用DS18B20测量室温并在数码管上显示。 * --------------------------------------…...
vue组合式和选项式
Vue中的组合式(Composition API)和选项式(Options API)是两种不同的编写组件逻辑的方法。 组合式API(Composition API): 使用函数来定义组件逻辑,可以更灵活地重用和组合逻辑。使用setup函数作为组件的入口点,在这里可以访问pro…...
使用OpenCV创建全景图像
使用OpenCV创建全景图像 前言图像拼接策略创建全景图像相关链接前言 在本节中,我们将学习组合多个图像来创建全景图像。使用相机拍摄全景照片时,通常会拍摄多张照片,通过算法将这些图像中共同存在的元素(从左到右)映射到一张单独的图像中。为了执行图像的拼接,将利用 cv2 …...
Nios II 实现流水灯实验
Nios II 实现流水灯实验 一.硬件设计1.新建Quartus项目2. 设计Nios ii 二.软件设计 前言 实验目标: 学习 Quartus 、Platform Designer、Nios-II SBT 的基本操作;初步了解 SOPC 的开发流程,基本掌握 Nios-II 软核的定制方法;掌握 …...
Spring boot 随笔 1 DatasourceInitializer
0. 为啥感觉升级了 win11 之后,电脑像是刚买回来的,很快 这篇加餐完全是一个意外:时隔两年半,再看 Springboot-quartz-starter 集成实现的时候,不知道为啥我的h2 在应用启动的时候,不能自动创建quartz相关…...
vue3_组件间通信方式
目录 一、父子通信 1.父传子( defineProps) 2.父传子(useAttrs) 3.子传父(ref,defineExpose ) 4.子传父(defineEmits) 5.子传父(v-model) …...
Triton模型服务化:构建高可用AI推理生产系统
1. 项目概述:当模型走出Jupyter,真正开始呼吸真实世界空气“From Notebook to Production: Running ML in the Real World (Part 4)”——这个标题本身就像一句暗号,专为那些在Jupyter里调通了模型、画出了漂亮ROC曲线、却在部署时被生产环境…...
Rainmeter桌面美化终极指南:轻松打造个性化Windows桌面的完整教程
Rainmeter桌面美化终极指南:轻松打造个性化Windows桌面的完整教程 【免费下载链接】rainmeter Desktop customization tool for Windows 项目地址: https://gitcode.com/gh_mirrors/ra/rainmeter Rainmeter是一款功能强大的Windows桌面自定义工具,…...
SystemVerilog驱动强度解析:从三态总线到功耗分析的核心技术
1. 项目概述:为什么需要关注驱动强度?在数字电路设计和验证领域,SystemVerilog 作为一门强大的硬件描述与验证语言,其细节往往决定了仿真的精度和设计的可靠性。很多工程师,尤其是刚接触 RTL 设计或转向更复杂验证场景…...
RTX166任务调度:K_IVL与K_TMO事件机制详解
1. RTX166任务调度中的K_IVL与K_TMO事件机制解析在RTX166实时操作系统中,os_wait函数提供的K_IVL和K_TMO事件是任务调度的核心机制。这两个看似相似的延时控制参数,在实际应用中却有着截然不同的行为模式。作为深耕嵌入式领域十余年的开发者,…...
金仓数据库KingbaseES自动创建表空间目录:简化运维,适配国产生态
目录 一、前言:传统表空间创建的运维痛点 二、自动创建表空间目录核心方案 2.1 核心控制参数 2.2 功能强制约束条件 2.3 多场景实操测试(含大小写混合路径) 场景1:目标目录已存在 场景2:目标目录部分存在 场景…...
保姆级教程:用Stata处理2000-2021年A股上市公司控制变量(附完整代码与数据)
Stata实战:A股上市公司控制变量构建全流程解析 第一次接触实证研究时,最让我头疼的不是模型设定,而是数据清洗。记得研一那年,导师扔给我一份从CSMAR导出的原始数据,要求两周内完成控制变量构建。面对密密麻麻的Excel表…...
DECO项目架构解析:从源码理解装饰器并发模型的设计哲学
DECO项目架构解析:从源码理解装饰器并发模型的设计哲学 【免费下载链接】deco 项目地址: https://gitcode.com/gh_mirrors/de/deco DECO(Decorated Concurrency)是一个革命性的Python并行计算框架,它通过装饰器实现了简洁…...
开源fNIRS脑机接口帽技术解析与应用
1. 开源可穿戴fNIRS脑机接口帽技术解析在神经工程领域,功能性近红外光谱(fNIRS)技术正逐渐成为研究大脑活动的重要工具。与传统的脑电图(EEG)或功能磁共振成像(fMRI)相比,fNIRS具有独…...
同城中高端软体家具哪个品牌好
在晋城家装市场,业主们常为“中高端软体家具品牌同城哪家强”犯难:怕被坑、担心质量、害怕超预算,成了本地装修的三大痛点。面对琳琅满目的家居品牌,如何选到靠谱门店?其实,本地正规实体家居门店才是“避坑…...
视频硬字幕提取神器:3分钟将任何视频字幕转为可编辑SRT文件
视频硬字幕提取神器:3分钟将任何视频字幕转为可编辑SRT文件 【免费下载链接】video-subtitle-extractor 视频硬字幕提取,生成srt文件。无需申请第三方API,本地实现文本识别。基于深度学习的视频字幕提取框架,包含字幕区域检测、字…...
