python-docx 实现 Word 办公自动化

前言:当我们需要批量生成一些合同文件或者简历等。如果手工处理对于我们来说不仅工作量巨大,而且难免会出现一些问题。这个时候运用python处理word实现自动生成文件可极大的提高工作效率。

python-docx是python的第三方插件,用来处理word文件,自动化生成和修改word文档。下面我们一起探讨一下如何工作的:

目录

一、安装

二、新建文档对象

三、写入内容

3.1插入文本

3.2添加图片和表格

3.3样式处理

四、保存文档

五、Word转换PDF

1.单个文件的转换

 2.多个文件转换

六、总结 


一、安装

1.下载安装

使用之前需要先下载安装。命令行:pip install python-docx

pip install python-docx

2.导入模块

import docx

一个简单的word创建过程:1.创建一个文件对象 2.添加内容 3.保存文件 

下面是一个生成word文件的简单步骤:

# 导入python-docx模块
import docx
from docx import Document#1.新建文档对象
document = Document() # 创建一个空的文档对象
#Document("storeinfo.docx") #读取现有的word 建立文档对象
#2.添加内容
document.add_heading("销售门店新增通知")
#3.保存文档
document.save("shop.docx")

 文件运行之后可以看到生成一个shop.docx文件。

可以看到非常简单只有一个文件标题的word文件。下面我们对详细用法进一步探索。

二、新建文档对象

在这里我们直接打开用刚刚生成的word文件来修改。

#1.新建文档对象
document = Document("shop.docx") #读取现有的word 建立文档对象

三、写入内容

前面我们添加的题目没有进行设置,所以默认使用一级标题显示,现在我们对添加的内容进行设置。

3.1插入文本

插入文本包括标题,段落,可以对标题进行等级设置,段落进行段落首行以及左右缩进,段落的行间距、文本的字体大小颜色字号设置,加粗、斜体、下划线常用的设置。

1)设置标题等级,首行以及左右缩进,行间距。

#2.添加内容
document.add_heading("销售门店新增通知",level=3)  #设置标题是4级标题
# 插入段落
p1 = document.add_paragraph("针对市场情况有变,现在某某地区新增某某门店,请知悉。")
p1.insert_paragraph_before("补充通知:这是在刚刚的段落之前插入新的段落哦")# 段落可以设置段落属性和段落中文字属性
format = p1.paragraph_format
format.left_indent = Pt(20) #段落左侧的缩进
format.right_indent = Pt(20) # 段落右侧的缩进
format.first_line_indent = Pt(20) #首行缩进设置20镑# 行间距
format.line_spacing = 1.5 

2) 字体、字号、颜色设置 

记得先导入 from docx.shared import Pt,RGBColor。

# 使用段落和颜色设置需要用到
from docx.shared import Pt,RGBColor# p1 追加文本并对本文进行字体大小设置
run = p1.add_run("具体信息请咨询总部具体信息请咨询总部具体信息请咨询总部具体信息请咨询总部具体信息请咨询总部具体信息请咨询总部具体信息请咨询总部")
# 设置字体字号以及颜色
run.font.size = Pt(12) 
run.font.name = '微软雅黑'
run.font.color.rgb = RGBColor(225,25,25)

字号和大小对比图 如下:

3)字体加粗下划线斜体设置

# 字体加粗下划线 斜体
run1 = p1.add_run("这里是段落继续增加的文字信息")
run1.bold = True
run1.font.underline = True
run1.font.italic = True

  

3.2添加图片和表格
#插入图片
document.add_picture('img.jpg') #插入图片 默认大小
document.add_picture('img.jpg',Pt(50),Pt(80)) #传入参设置插入图片的大小# 插入表格
table = document.add_table(rows=1,cols=3) #设置一行三列的数据表
headerCells = table.rows[0].cells
headerCells[0].text = "月份"
headerCells[1].text = "预期产量"
headerCells[2].text = "实际产量"# 数据
data = (['一月份',100,120],['二月份',300,350],['三月份',600,500]
)for item in data:rowsCells = table.add_row().cells rowsCells[0].text = item[0]rowsCells[1].text = str(item[1])rowsCells[2].text = str(item[2])

执行结果:

3.3样式处理

包括样式设置以及删除已添加样式。

# 导入文件
from docx.enum.style import WD_STYLE_TYPEstyle = document.styles.add_style('textstyle',WD_STYLE_TYPE.PARAGRAPH)
style.font.size = Pt(5)
#删除样式
#document.styles['textstyle'].delete()# 插入段落 在这里插入文本样式作为参数传递
p1 = document.add_paragraph("针对市场情况有变,现在某某地区新增某某门店,请知悉。针对市场情况有变,现在某某地区新增某某门店,请知悉。""针对市场情况有变,现在某某地区新增某某门店,请知悉。针对市场情况有变,现在某某地区新增某某门店,请知悉。" ,style='textstyle')# 插入表格 这里也是
table = document.add_table(rows=1,cols=3,style='Medium List 1') 

四、保存文档

#3.保存文档
document.save("shop.docx")

五、Word转换PDF

安装依赖并导入

# 安装
pip install pywin32
# 导入
from win32com.client import constants,gencache

1.单个文件的转换
def createpdf(wordPath,pdfPath):word = gencache.EnsureDispatch('Word.Application')doc = word.Documents.Open(wordPath,ReadOnly=1)# 转换方法doc.ExportAsFixedFormat(pdfPath,constants.wdExportFormatPDF)word.Quit()
#单个文件的转换
createpdf('D:\CODE\VSCODE\python\demo\shop.docx','D:\CODE\VSCODE\python\demo\shop.pdf')    

执行之后可以看到生成了shop.pdf文件 。

 2.多个文件转换
# 对目录的操作 多文件转换pdf
import os#多个文件的转换
# print(os.listdir('.')) #当前文件夹下的所有文件#定义一个列表用来存放当前文件夹下所有的doc或者docx文件
wordfiles = []
# 遍历当前文件夹下的所有文件
for file in os.listdir('.'):if file.endswith(('doc','docx')): #如果以doc或者docx结果的都添加到wordfiles列表中wordfiles.append(file)
# print(wordfiles) 
# 
# 遍历doc和docx文件   
for file in wordfiles:filepath = os.path.abspath(file) # 获取到当前的文件路径index = filepath.rindex('.') #找到最后一次出现‘.’的地址pdfpath = filepath[:index]+'.pdf'   #filepath[:index] 获取从 filepath‘.’之前的字符 然后拼接'.pdf'# print(pdfpath) createpdf(filepath,pdfpath)  # 执行转换操作

执行文件之后文件夹生成了几个pdf文件。 

六、总结

本章主要总结了python-docx的第三方模块主要用于添加和修改word文件。

1.首先对python-docx模块进行安装并且导入依赖使用

2.模块的主要工作过程 新建文档对象 写入内容、保存文档

3.写入内容又分为写入文本、添加图片表格

4.对添加的段落、标题以及文字进行样式设置

5.word转换pdf单个文件和多个文件转换

有问题欢迎大家评论区留言指正,大家一起探讨学习一起进步,谢谢。

题库数据经过打乱试题和答案后生成word试卷案例

Python 办公自动化 处理 Excel 数据 | python环境下载安装 | python网络爬虫爬数据

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

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

相关文章

Kubectl命令、初识pod、namespace

文章目录 一、Kubectl简介基础命令1.基本信息命令2.创建和更新资源命令3.删除资源命令4. 查看日志和调试命令5. 端口转发和复制文件命令6. 部署管理命令7. 伸缩命令8. 配置和上下文管理命令9.常用命令 二、Pod简介核心概念pod常见状态调度和初始化阶段容器创建和运行阶段异常状…

Qt网络通信——TCP和UDP

一、TCP通信 TCP通信必须先建立 TCP 连接,通信端分为客户端和服务器端。 Qt 为服务器端提供了 QTcpServer 类用于实现端口监听,QTcpSocket 类则用于服务器和客户端之间建立连接。大致流程如下图所示: 1. 服务器端建立 1.1 监听——listen() …

PPP简介

介绍PPP特性的定义和目的。 定义 PPP(Point-to-Point Protocol)协议是一种点到点链路层协议,主要用于在全双工的同异步链路上进行点到点的数据传输。 目的 PPP协议是在串行线IP协议SLIP(Serial Line Internet Protocol&#x…

代码随想录:动态规划6-10

62、不同路径 题目 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” )。 问总共有多少条不同的路径…

史上最全的软件工厂考试简答题教程

软件工程考试简答题 1. 有人认为软件开发时,一个错误发现得越晚,为改正它所付出的代价越大。提出你的观点并解释原因? (1)在软件开发的不同阶段进行修改付出的代价是很不相同的,在早期引入变动&#xff0c…

openai whisper使用

whisper使用 介绍 Whisper是一种通用的语音识别模型。它是在大量不同音频数据集上训练的,也是一个多任务模型,可以执行多语言语音识别、语音翻译和语言识别。 GitHub:https://github.com/openai/whisper 论文链接:https://arx…

注册Github账号详细过程

目录 一、准备工作 二、注册步骤 一、准备工作 在注册GitHub账号之前,请确保您已经准备好以下信息: 一个有效的电子邮箱地址:用于接收验证邮件和GitHub的后续通知。 用户名:确保该用户名在GitHub上是唯一的,且符合…

turtle画图知识

Turtle库是Python编程语言中的一个库,用于创建各种类型的图形,包括简单圆形、线条、路径和图片。它支持多种图形类型,并且可以绘制出各种复杂的形状。 以下是一些基本的使用方法: 1. 创建一个新的Turtle对象: pytho…

Leetcode JAVA刷刷站(53)最大子数组和

一、题目概述 二、思路方向 这个问题是一个经典的算法问题,称为“最大子序和”(Maximum Subarray Problem)。解决这个问题的一个高效方法是使用“Kadanes Algorithm”,它只需要遍历数组一次,就能在 O(n) 时间复杂度内…

CVPR2023《DNF: Decouple and Feedback Network for Seeing in the Dark》暗光图像增强论文阅读笔记

相关链接 论文链接 https://openaccess.thecvf.com/content/CVPR2023/papers/Jin_DNF_Decouple_and_Feedback_Network_for_Seeing_in_the_Dark_CVPR_2023_paper.pdf 代码链接 https://github.com/Srameo/DNF 摘要 RAW数据的独特属性在低光照图像增强方面展现出巨大潜力。…

C语言典型例题47

《C程序设计教程(第四版)——谭浩强》 习题3.7 输入4个整数,要求按照从小到大的顺序输出 4个数之间进行比较,冒泡排序最最最详细过程,如果想更改为任意数之间相互比较,只需要修改两个地方(数组大…

力扣面试经典算法150题:买卖股票的最佳时机 II

买卖股票的最佳时机 II 今天的题目是力扣面试经典150题中的数组的中等难度题:买卖股票的最佳时机 II。 题目链接:https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-ii/description/?envTypestudy-plan-v2&envIdtop-interview-150 问…

教程:postman的平替hoppscotch,又叫postwoman,hoppscotch的docker-compose安装过程

目录 1. 背景2. 前期准备2.1 准备docker-compose文件,两个版本,一个3合1,一个分开2.1.1 3合1版本(推荐)2.1.2 独立版本 2.2 准备安装nginx-proxy-manager(可选)2.2 准备.env文件2.2.1 默认ip的.…

Spring Boot OAuth2.0应用

本文展示Spring Boot中,新版本OAuth2.0的简单实现,版本信息: spring-boot 2.7.10 spring-security-oauth2-authorization-server 0.4.0 spring-security-oauth2-client 5.7.7 spring-boot-starter-oauth2-resource-server 2.7.10展示三个服务…

Android高版本抓包总结

方案1 CharlesVirtualXposedJustTrustMe 推荐使用三星手机此方案 VirtualXposed下载链接:https://github.com/android-hacker/VirtualXposed/releases JustTrustMe下载链接:https://github.com/Fuzion24/JustTrustMe/releases/ 下载完成后使用adb命令…

从易车“超级818冠军之夜” 看如何借势体育营销点燃汽车消费热潮

编辑 | 魏力 发布 | 大力财经 导语:这个8月,是属于奥运的8月。 巴黎奥运会虽圆满落幕,但属于奥运健儿们的热度还在持续。在这股奥运热潮的带动下,全民运动热情持续释放,同时也激发出巨大的消费潜力。 赛场外&#…

黄热病疫苗市场调研:预计到 2030 年全球市场规模将达到 1.8 亿美元

一、黄热病疫苗市场研究 (一)发展趋势 1. 市场规模增长:据调研团队报告所示,预计到 2030 年全球黄热病疫苗市场规模将达到 1.8 亿美元,年复合增长率为 3.0%。这表明市场在未来几年将保持稳定增长态势。增长的原因主要…

LSI-9361阵列卡笔记

背景 要将raid0更改为JBOD直通模式 注意的点是要先将raid模式调整为JBOD之后重启机器,即可 备注:转换过程中硬盘中的数据未丢失。 步骤贴图 refer https://zhiliao.h3c.com/questions/dispcont/123250 https://blog.csdn.net/GreapFruit_J/article/…

Android Activity启动流程(Android 13)

文章目录 Android Activity启动流程(Android 13)概述流程图前提流程分析Activity#startActivity()Activity#startActivityForResult()Instrumentation#execStartActivity()ActivityTaskManager#getService() ActivityTaskManagerService#startActivity()ActivityTaskManagerSer…

解决window 端口的占用问题

netstat -nao | findstr "5554" taskkill -pid 5076 -f 本文资料来自 https://cloud.tencent.com/developer/article/1703982