Python3处理文档_word文档实现自动化办公(一)
最近打算写一个自动化出报告的脚本
先从处理word文档开始
Python 操作 Word 最常见的依赖库是:python-docx
所以,在开始操作之前,我们需要在虚拟环境下安装这个依赖库
pip3 install python-docx
开始学习
我们需要了解一个 Word 文档的页面结构
它们分别是:
文档 - Document
章节 - Section
段落 - Paragraph
文字块 - Run
此外一个Word文档,经常操作的数据类型包含:段落、标题、列表、图片、表格、样式,都有对应的方法处理:
标题:add_heading()
段落:add_paragraph()
文本:add_run(),其返回对象支持设置文本属性
图片:add_picture()
表格:add_table()、add_row()、add_col()
一、首先,使用 Document 创建一个文档对象,相当于创建一个空白文档
from docx import Document
doc_test = Document()#首先,使用 Document 创建一个文档对象,相当于创建一个空白文档
doc_test.save('test.docx')
运行结果:

二、Python-docx 编辑已存在文档
from docx import Document
doc=Document('exist.docx')
doc.save('new.docx')
运行结果:

三、然后,就可以往文档中写入数据了
1、使用文档对象的 add_heading(text,level) 方法可以写入标题
其中,第 1 个参数为标题内容,第 2 个参数代表标题的级别
比如:分别写入一级标题、二级标题、三级标题(等级1-9 )
#分别写入一个一级标题,一个二级标题,一个三级标题
#分别写入一个一级标题,一个二级标题,一个三级标题
from docx import Document
doc=Document()
doc.add_heading('一级标题', 0)
doc.add_heading('二级标题', 1)
doc.add_heading('正文:道可道,非常道', 9)
doc.add_heading('三级标题', 2)
doc.save('1.docx')
#
运行结果:

2、段落 Paragraph 包含 3 类,分别是:
普通段落
自定义样式的段落
引用段落
默认情况下,使用文档对象的 add_paragraph(text,style) 方法来添加一个段落
普通段落:假如第二个参数 style 没有传入,则代表添加一个普通的段落
引用段落:对于引用段落,只需要指定段落样式为 Intense Quote 即可
#分别写入一个一级标题,一个二级标题,一个三级标题
from docx import Document
doc=Document()
doc.add_heading('一级标题', 0)
doc.add_heading('二级标题', 1)
doc.add_heading('正文:道可道,非常道', 9)
doc.add_heading('三级标题', 2)
# 2.2.1 新增普通段落
doc.add_paragraph("我是一个普通段落。")
# 2.2.3 新增一个引用段落
# 只需要指定样式为:Intense Quote
doc.add_paragraph('--我是一个引用段落--', style='Intense Quote')
doc.save('1.docx')
运行结果:

自定义样式的段落:这里有 2 种实现方式
分别是:
(1)创建一个空的段落对象,增加文字块 Run 的时候,同时指定字体样式
(2)使用文档对象创建一个新的样式(或已经存在的样式),然后添加段落的时候,设置到第二个参数中
考虑到样式的样式的复用性,第 2 种方式可能更实用
对应的方法是:
document.styles.add_style(style_name,type)
创建自定义段落样式(第一个参数为样式名, 第二个参数为样式类型, 1为段落样式, 2为字符样式, 3为表格样式)
def create_style(document, style_name, style_type, font_size=-1, font_color=None, font_name=None, align=None):
"""
创建一个样式
:param align:
:param document:
:param style_name: 样式名称
:param style_type: 样式类型,1:段落样式, 2:字符样式, 3:表格样式
:param font_name:
:param font_color:
:param font_size:
:return:
"""
def create_style(document, style_name, style_type, font_size=-1, font_color=None, font_name=None, align=None):
"""
对应字体:
八号= 5 磅 (5pt) = (5/72)*96 = 6.67 = 6px
七号= 5.5 磅= (5.5/72)*96 = 7.3 = 7px
小六= 6.5 磅= (6.5/72)*96 = 8.67 = 8px
六号= 7.5 磅= (7.5/72)*96 = 10px
小五= 9 磅= (9/72)*96 = 12px
五号= 10.5 磅= (10.5/72)*96 = 14px
小四= 12 磅= (12/72)*96 = 16px
四号= 14 磅= (14/72)*96 = 18.67 = 18px
小三= 15 磅= (15/72)*96 = 20px
三号= 16 磅= (16/72)*96 = 21.3 = 21px
小二= 18 磅= (18/72)*96 = 24px
二号= 22 磅= (22/72)*96 = 29.3 = 29px
小一= 24 磅= (24/72)*96 = 32px
一号= 26 磅= (26/72)*96 = 34.67 = 34px
小初= 36 磅= (36/72)*96 = 48px
初号= 42 磅= (42/72)*96 = 56px
"""
if font_color is None:
font_color = []
# 注意:必须要判断样式是否存在,否则重新添加会报错
style_names = [style.name for style in document.styles]
if style_name in style_names:
# print('样式已经存在,不需要重新添加!')
return
font_style = document.styles.add_style(style_name, style_type)
# 字体大小
if font_size != -1:
font_style.font.size = Pt(font_size)
# 字体颜色
font_style.font.color.rgb = RGBColor(0,0,0)
# 对齐方式
# 注意:段落、表格才有对齐方式
if style_type != 2 and align:
font_style.paragraph_format.alignment = align
# font_style.paragraph_format.alignment = WD_PARAGRAPH_ALIGNMENT.CENTER
# font_style.paragraph_format.alignment = WD_PARAGRAPH_ALIGNMENT.LEFT
# font_style.paragraph_format.alignment = WD_PARAGRAPH_ALIGNMENT.RIGHT
# 字体名称
if font_name:
font_style.font.name = font_name
font_style.font.name = 'Times New Roman'
# 中文字体名称
font_style._element.rPr.rFonts.set(qn('w:eastAsia'), font_name)
##这里实际上是font_style._element
##font_style._element 再.rPr.rFonts.set
return font_style
doc.add_paragraph('--我是一个引用段落--', style='Intense Quote')
style_paragraph = create_style(document=doc, style_name="style2", style_type=1, font_size=10.5,font_name='宋体')
doc.add_paragraph('我是是调用样式方法create_style创建的',style_paragraph)
运行结果:
行间距调整
加粗\倾斜
p=doc.add_paragraph('我是')
p.add_run('加粗').bold = True
p.add_run('倾斜').italic = True
运行:

明天继续:
我公众号大家可以关注支持一哈
主要记录一些网络安全和Python的学习。

Python3处理文档_word文档实现自动化办公(一)的更多相关文章
- 把 MWeb Lite 的文档库文档和数据搬到 MWeb 正式版中
MWeb Lite 版的文档库中的文档要搬到 MWeb 正式版中,如果 Lite 版的文档中没有图片或者只有少量图片,可以用导入导出为 Markdown 的方法. 否则的话请用以下方式(注意下面这个方 ...
- 使用C#动态生成Word文档/Excel文档的程序测试通过后,部署到IIS服务器上,不能正常使用的问题解决方案
使用C#动态生成Word文档/Excel文档的程序功能调试.测试通过后,部署到服务器上,不能正常使用的问题解决方案: 原因: 可能asp.net程序或iis访问excel组件时权限不够(Ps:Syst ...
- 关于HTML文档的文档模式
HTML文档的文档模式包括混杂模式和标准模式,这两种模式主要影响CSS内容的呈现,但在某些情况下也会影响到JavaScript的解释执行. 如果在文档开始处没有发现文档类型声明,则所有浏览器都会默认开 ...
- 返回当前文档的文档的url
HTML DOM referrer 属性 HTML DOM Document 对象 定义和用法 referrer 属性可返回载入当前文档的文档的 URL. 语法 document.referrer 说 ...
- 创建MFC应用程序的类型:单文档+多文档+基于对话框
单文档支持文档视图架构.数据的保存--(读取--改动)文档类功能--显示(视图类功能),比較方便. 基于对话框,主窗体是对话框类型.能够方便的使用控件,所见即所得的编程,比較方便. 单文档类似&quo ...
- 解决Spring的java项目打包后执行出现“无法读取方案文档...“、“原因为 1) 无法找到文档; 2) 无法读取文档; 3) 文档的根元素不是...”问题
问题 一个用Spring建的java项目,在Eclipse或idea中运行正常,为什么打包后运行出现如下错误呢? 2019/07/10/19:04:07 WARN [main] org.springf ...
- MongoDB 大数据技术之mongodb中在嵌套子文档的文档上面建立索引
一.给collection objectid赋自定义的值 MongoDB Enterprise > db.testid.insert({_id:{imsi:"4567890123&qu ...
- SharePoint 开发另存文档库中文档
前言 最近碰到这样一个问题,用前端框架读取SharePoint文档库中文档的时候,如果是PDF/TXT等类型的文档,不会出现另存为的操作,而是在浏览器中在线打开,这样用户是无法接受的. 解决方法 通过 ...
- 懒得写文档,swagger文档导出来不香吗
导航 前言 离线文档 1 保存为html 2 导出成pdf文档 3 导出成Word文档 参考 前言 早前笔者曾经写过一篇文章<研发团队,请管好你的API文档>.团队协作中,开发文档的重 ...
- 如何通过Java代码向Word文档添加文档属性
Word文档属性包括常规.摘要.统计.内容.自定义.其中摘要包括标题.主题.作者.经理.单位.类别.关键词.备注等项目.属性相当于文档的名片,可以添加你想要的注释.说明等.还可以标注版权. 今天就为大 ...
随机推荐
- “翼”鸣惊人,天翼云两篇论文被ACM ICPP 2024收录!
*日,由天翼云科技有限公司弹性计算产品线天玑实验室撰写的两篇论文<PheCon: Fine-Grained VM Consolidation with Nimble Resource Defra ...
- oracle 常用函数2
1.ASCII 2 2.CHR. 2 3.CONCAT. 2 4.INITCAP. 2 5.INSTR(C1,C2,I,J) 3 6.LENGTH *. 3 7.LOWER. 3 8.UPPER. 3 ...
- IDEA debug时候直接报ClassNotFoundException,代码正常,也可以正常运行
原因,是因为在某些类误点了断点,需要取消
- windows10专业版代码永久激活
1."Win+R"打开运行对话框,输入命令slmgr.vbs -xpr 可以查看当前系统的激活信息 2. 在电脑图标右键,打开属性,查看自己win10系统版本 3. 在开始菜单右键 ...
- HTML - 1、基础
<!DOCTYPE html> <!-- 指定网页内容的语言 --> <html lang="en"> <head> <!-- ...
- 记录一次WPF程序进程挂起问题
## 1. 使用背景 开发`WPF`单进程项目,在项目中使用`MongoDB`数据库,需要连接多个不同的数据库实例,另外项目框架采用了事件聚合器来管理模块间的通知调用,基于`NetMQ`实现了一个`Z ...
- Deepseek官网太卡,教你白嫖阿里云的Deepseek-R1满血版
Deepseek卡的问题已经有几周了,还有同学没有解决这个问题? 今天就来教大家如何白嫖阿里云的Deepseek-R1满血版,新用户享受100万token额度,相当的富裕,可以随便用了.并且还配用AP ...
- 收集 Spring Boot 相关的学习资料
收集 Spring Boot 相关的学习资料,Spring Cloud点这里 重点推荐:Spring Boot 中文索引 推荐博客 纯洁的微笑-Spring Boot系列文章 林祥纤-从零开始学Spr ...
- Ubuntu如何下载nvidia驱动和Cuda Toolkit
Ubuntu如何下载nvidia驱动和Cuda Toolkit 前言 手快不小心把 nvidia 的某个东西删除了,现在不得不全部卸载后再重新安装了. 我再也不敢在不确认内容的情况下,确认删除了 ...
- 修改npm下载地址为淘宝镜像
修改 npm 下载地址 修改为国内淘宝镜像 # 修改为新淘宝镜像(推荐) npm config set registry https://registry.npmmirror.com/ # 旧 npm ...

