python-docx 实现 Word 办公自动化

news2025/2/5 19:52:51

前言:当我们需要批量生成一些合同文件或者简历等。如果手工处理对于我们来说不仅工作量巨大,而且难免会出现一些问题。这个时候运用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_TYPE

style = 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网络爬虫爬数据

 

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

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

相关文章

UPS快递查询|利用API对接国际物流轨迹

聚合国内外1500家快递公司的物流信息查询服务,使用API接口查询UPS快递的便捷步骤,首先选择专业的数据平台的快递API接口:https://www.tanshuapi.com/market/detail-68 以下示例是参考的示例代码: import requestsurl "http…

gstreamer系列 -- 获取媒体信息

Basic tutorial 9: Media information gathering

PyCharm单步调试

1、先在入口设置断点,再点击爬虫图标(shift F9)开始调试 调试图标如图: 2、蓝色光标表示当前运行在这行 3、快捷键 F7:进入当前行函数 F8:单步 F9:全速运行

语言基础/分析和实践 CC++ 位域结构数据类型

文章目录 概述位域和结构体的关系位域/位段的概念位域定义的语法位段结构的利弊 结构字段的定义和存储顺序小端系统上的结构字段存储大端系统上的结构字段存储小结(承上启下) 位域结构的存储(对齐、填充、跨字节)位域结构的Bit位序…

admob 广告分析

1、测试广告集成,官方文档 https://developers.google.com/admob/android/quick-start?hlzh-cn dependencies {implementation("com.google.android.gms:play-services-ads:23.3.0") }2、广告集成,集成测试激励广告。 public class MainAct…

学习大数据DAY41 Hive 分区表创建

目录 分区表 分区表应用场景 oracle 分区表种类 oracle 分区-范围分区 oracle 分区-列表分区 oracle 分区-散列分区 oracle 分区-组合分区 oracle 分区-分区表操作 hive 分区-创建分区表 hive 分区-分区表操作 hive 分区-动态分区表配置 上机练习 分区表 分区是将一…

常见古典密码介绍

文章目录 Vigenre 密码变异凯撒摩斯密码栅栏密码加密方式一加密方式二 Caesar和ROT13的区别ROT13加密原理ROT13查找表 Vigenre 密码 由于频率分析法可以有效的破解单表替换密码,法国密码学家维吉尼亚于1586年提出一种多表替换密码,   即维吉尼亚密码&…

什么是局域网管理软件?这款局域网管理软件简直太好用了丨好物分享

在信息技术日新月异的今天,企业的内部网络管理如同古代战场上的排兵布阵,需有精良之器以应对复杂多变的局势。 局域网,作为企业内部信息交流与资源共享的重要平台,其管理效率与安全性直接影响到企业的运营与发展。 一、局域网管理…

Docker-安装软件

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、安装MySQL(一)拉取MySQL镜像(二)运行MySQL容器(1)数据卷概念 (三&#x…

开发 LLM 支持的应用程序:Azure 上的 Llama 2(5/n)

微软与 Meta 联手在 Azure 上提供 Meta 的开源大型语言模型 (LLM) Llama 2,打开了闸门!信不信由你,这是一件大事。 亚马逊的 AWS 于去年年底发布了 Amazon SageMaker Jumpstart,它与 Azure 类似,支持部署开源模型供公共…

常见而不容忽视,电器中微型紧固件的四大影响

技术和创新催生了数以百万计的电器,它们已成为每个家庭和人类日常使用的一部分。从微波炉和冰箱到笔记本电脑和智能手机,这些部件的技术影响正在迅速增长,成为现代生活的一部分。 在许多人的不经意间,这些功能强大的发明为我们许多…

[Linux#42][线程] 锁的接口 | 原理 | 封装与运用 | 线程安全

互斥量 mutex • 大部分情况,线程使用的数据都是局部变量,变量的地址空间在线程栈空间 内,这种情况,变量归属单个线程,其他线程无法获得这种变量。 • 但有时候,很多变量都需要在线程间共享,这…

代码随想录算法训练营第二十一天(二叉树 八)

今天是二叉树复习最后一天! 力扣题部分: 669. 修剪二叉搜索树 题目链接:. - 力扣(LeetCode) 题面: 给你二叉搜索树的根节点 root ,同时给定最小边界low 和最大边界 high。通过修剪二叉搜索树,使得所有节点的值在[low…

使用 Dify 和 AI 大模型理解视频内容:Qwen 2 VL 72B

接下来的几篇相关的文章,聊聊使用 Dify 和 AI 大模型理解视频内容。 本篇作为第一篇内容,以昨天出圈的“黑神话悟空制作人采访视频”为例,先来聊聊经常被国外厂商拿来对比的国产模型:千问系列,以及它的内测版。 写在…

Linux非VP扩容方案

Linux系统非VP扩容方案 描述:现有虚拟机磁盘1TB 容量不够,需要扩容。 采用:https://bbs.sangfor.com.cn/forum.php?modviewthread&tid110403 扩容失败。原因是没有VP 和LV 解决方案: 1,查看分区 cat /proc/p…

鸿蒙内核源码分析(中断概念篇) | 海公公的日常工作

关于中断部分系列篇将用三篇详细说明整个过程. 中断概念篇 中断概念很多,比如中断控制器,中断源,中断向量,中断共享,中断处理程序等等.本篇做一次整理.先了解透概念才好理解中断过程.本篇的主角是海公公,用…

全国计算机二级C语言笔试试题及答案

一、选择题(每小题2分,共70分)   下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。 请将正确选项填涂在答题卡相应位置上,答在试卷上不得分。   (1)下列叙述中正确的是 A)线性表的链式存储结构与顺序存储结构所需要的存储空间是相同的 …

day06-SpringBootWeb请求响应

前言 在上一次的课程中,我们开发了springbootweb的入门程序。 基于SpringBoot的方式开发一个web应用,浏览器发起请求 /hello 后 ,给浏览器返回字符串 “Hello World ~”。 其实呢,是我们在浏览器发起请求,请求了我们的…

[Meachines] [Easy] Bastion SMB未授权访问+VHD虚拟硬盘挂载+注册表获取NTLM哈希+mRemoteNG远程管理工具权限提升

信息收集 IP AddressOpening Ports10.10.10.134TCP:22, 135, 139, 445, 5985, 47001, 49664, 49665, 49666, 49667, 49668, 49669, 49670 $ nmap -p- 10.10.10.134 --min-rate 1000 -sC -sV PORT STATE SERVICE VERSION 22/tcp open ssh OpenSSH fo…

Bonree ONE 3.0:全域可观测 运维新境界

2024年8月16日,备受瞩目的Bonree ONE 3.0产品发布会上海站在上海中心大厦隆重举行。此次发布会以”Take IT Easy“——全域可观测,运维新境界为主题,博睿数据正式发布了一体化智能可观测平台Bonree ONE 3.0版本。Bonree ONE 3.0凭借领先的全域…