python-docx 实现 Word 办公自动化

2024-08-21 00:52

本文主要是介绍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单个文件和多个文件转换

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

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

 

这篇关于python-docx 实现 Word 办公自动化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

SpringBoot使用ffmpeg实现视频压缩

《SpringBoot使用ffmpeg实现视频压缩》FFmpeg是一个开源的跨平台多媒体处理工具集,用于录制,转换,编辑和流式传输音频和视频,本文将使用ffmpeg实现视频压缩功能,有需要的可以参考... 目录核心功能1.格式转换2.编解码3.音视频处理4.流媒体支持5.滤镜(Filter)安装配置linu

在Spring Boot中实现HTTPS加密通信及常见问题排查

《在SpringBoot中实现HTTPS加密通信及常见问题排查》HTTPS是HTTP的安全版本,通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护,下面通过本文给大家介绍在SpringB... 目录一、HTTPS核心原理1.加密流程概述2.加密技术组合二、证书体系详解1、证书类型对比2. 证书获

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3