Python使用python-docx读写word文档


Posted in Python onAugust 26, 2019

python-docx库可用于创建和编辑Microsoft Word(.docx)文件。

官方文档:链接地址

备注:

doc是微软的专有的文件格式,docx是Microsoft Office2007之后版本使用,其基于Office Open XML标准的压缩文件格式,比 doc文件所占用空间更小。docx格式的文件本质上是一个ZIP文件,所以其实也可以把.docx文件直接改成.zip,解压后,里面的 word/document.xml包含了Word文档的大部分内容,图片文件则保存在word/media里面。

python-docx不支持.doc文件,间接解决方法是在代码里面先把.doc转为.docx。

一、安装包

pip3 install python-docx

二、创建word文档

下面是在官文示例基础上对个别地方稍微修改,并加上函数的使用说明

from docx import Document
from docx.shared import Inches
 
document = Document()
 
#添加标题,并设置级别,范围:0 至 9,默认为1
document.add_heading('Document Title', 0)
 
#添加段落,文本可以包含制表符(\t)、换行符(\n)或回车符(\r)等
p = document.add_paragraph('A plain paragraph having some ')
#在段落后面追加文本,并可设置样式
p.add_run('bold').bold = True
p.add_run(' and some ')
p.add_run('italic.').italic = True
 
document.add_heading('Heading, level 1', level=1)
document.add_paragraph('Intense quote', style='Intense Quote')
 
#添加项目列表(前面一个小圆点)
document.add_paragraph(
 'first item in unordered list', style='List Bullet'
)
document.add_paragraph('second item in unordered list', style='List Bullet')
 
#添加项目列表(前面数字)
document.add_paragraph('first item in ordered list', style='List Number')
document.add_paragraph('second item in ordered list', style='List Number')
 
#添加图片
document.add_picture('monty-truth.png', width=Inches(1.25))
 
records = (
 (3, '101', 'Spam'),
 (7, '422', 'Eggs'),
 (4, '631', 'Spam, spam, eggs, and spam')
)
 
#添加表格:一行三列
# 表格样式参数可选:
# Normal Table
# Table Grid
# Light Shading、 Light Shading Accent 1 至 Light Shading Accent 6
# Light List、Light List Accent 1 至 Light List Accent 6
# Light Grid、Light Grid Accent 1 至 Light Grid Accent 6
# 太多了其它省略...
table = document.add_table(rows=1, cols=3, style='Light Shading Accent 2')
#获取第一行的单元格列表
hdr_cells = table.rows[0].cells
#下面三行设置上面第一行的三个单元格的文本值
hdr_cells[0].text = 'Qty'
hdr_cells[1].text = 'Id'
hdr_cells[2].text = 'Desc'
for qty, id, desc in records:
 #表格添加行,并返回行所在的单元格列表
 row_cells = table.add_row().cells
 row_cells[0].text = str(qty)
 row_cells[1].text = id
 row_cells[2].text = desc
 
document.add_page_break()
 
#保存.docx文档
document.save('demo.docx')

创建的demo.docx内容如下:

 Python使用python-docx读写word文档

三、读取word文档

from docx import Document
 
doc = Document('demo.docx')
 
#每一段的内容
for para in doc.paragraphs:
 print(para.text)
 
#每一段的编号、内容
for i in range(len(doc.paragraphs)):
 print(str(i), doc.paragraphs[i].text)
 
#表格
tbs = doc.tables
for tb in tbs:
 #行
 for row in tb.rows: 
 #列 
 for cell in row.cells:
 print(cell.text)
 #也可以用下面方法
 '''text = ''
 for p in cell.paragraphs:
 text += p.text
 print(text)'''

运行结果:

Document Title
A plain paragraph having some bold and some italic.
Heading, level 1
Intense quote
first item in unordered list
second item in unordered list
first item in ordered list
second item in ordered list
Document Title
A plain paragraph having some bold and some italic.
Heading, level 1
Intense quote
first item in unordered list
second item in unordered list
first item in ordered list
second item in ordered list
 
 
 
Qty
Id
Desc
101
Spam
422
Eggs
631
Spam, spam, eggs, and spam
[Finished in 0.2s]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python中lambda与def用法对比实例分析
Apr 30 Python
Python中的自省(反射)详解
Jun 02 Python
详解字典树Trie结构及其Python代码实现
Jun 03 Python
Python实现的人工神经网络算法示例【基于反向传播算法】
Nov 11 Python
Python文本特征抽取与向量化算法学习
Dec 22 Python
火车票抢票python代码公开揭秘!
Mar 08 Python
Anaconda2下实现Python2.7和Python3.5的共存方法
Jun 11 Python
python中scikit-learn机器代码实例
Aug 05 Python
Django model 中设置联合约束和联合索引的方法
Aug 06 Python
python 下载文件的多种方法汇总
Nov 17 Python
Python进程间的通信之语法学习
Apr 11 Python
python模板入门教程之flask Jinja
Apr 11 Python
Python Subprocess模块原理及实例
Aug 26 #Python
python自动循环定时开关机(非重启)测试
Aug 26 #Python
Python 字符串类型列表转换成真正列表类型过程解析
Aug 26 #Python
Python类中的魔法方法之 __slots__原理解析
Aug 26 #Python
pywinauto自动化操作记事本
Aug 26 #Python
Python 实现的 Google 批量翻译功能
Aug 26 #Python
python自动化工具之pywinauto实例详解
Aug 26 #Python
You might like
PHP仿博客园 个人博客(1) 数据库与界面设计
2013/07/05 PHP
对PHP依赖注入的理解实例分析
2016/10/09 PHP
ie 调试javascript的工具
2009/04/29 Javascript
详解jQuery插件开发中的extend方法
2013/11/19 Javascript
正则表达式中特殊符号及正则表达式的几种方法总结(replace,test,search)
2013/11/26 Javascript
在Linux上用forever实现Node.js项目自启动
2014/07/09 Javascript
Jquery仿IGoogle实现可拖动窗口示例代码
2014/08/22 Javascript
JavaScript 学习笔记之操作符
2015/01/14 Javascript
jQuery仿gmail实现fixed布局的方法
2015/05/27 Javascript
超漂亮的jQuery图片轮播特效
2015/11/24 Javascript
JS转换HTML转义符的方法
2016/08/24 Javascript
微信小程序 Tab页切换更新数据
2017/01/05 Javascript
jQuery实现表格元素动态创建功能
2017/01/09 Javascript
JS数组搜索之折半搜索实现方法分析
2017/03/27 Javascript
使用javaScript实现鼠标拖拽事件
2020/04/03 Javascript
JavaScript中EventLoop介绍
2018/01/22 Javascript
Vue-Router2.X多种路由实现方式总结
2018/02/09 Javascript
微信小程序使用npm包的方法步骤
2019/08/13 Javascript
vue input标签通用指令校验的实现
2019/11/05 Javascript
javascript利用键盘控制小方块的移动
2020/04/20 Javascript
Element DateTimePicker日期时间选择器的使用示例
2020/07/27 Javascript
初学python数组的处理代码
2011/01/04 Python
用Python脚本生成Android SALT扰码的方法
2013/09/18 Python
玩转python爬虫之爬取糗事百科段子
2016/02/17 Python
浅谈编码,解码,乱码的问题
2016/12/30 Python
python递归全排列实现方法
2018/08/18 Python
印度排名第一的蛋糕、鲜花和礼品送货:Winni
2019/08/02 全球购物
迪卡侬中国官网:Decathlon中国
2020/08/10 全球购物
Java中有几种类型的流?JDK为每种类型的流提供了一些抽象类以供继承,请说出他们分别是哪些类
2012/02/06 面试题
数据库测试通常都包括哪些方面
2015/11/30 面试题
职高毕业生自我鉴定
2013/10/21 职场文书
电大物流学生的自我评价
2013/10/25 职场文书
业务助理岗位职责
2013/11/18 职场文书
老同学聚会感言
2014/02/23 职场文书
英语求职信范文
2014/05/23 职场文书
gateway网关接口请求的校验方式
2021/07/15 Java/Android