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中的join()函数的用法
Apr 07 Python
使用Python中的线程进行网络编程的入门教程
Apr 15 Python
Python实现自动添加脚本头信息的示例代码
Sep 02 Python
pycharm运行出现ImportError:No module named的解决方法
Oct 13 Python
python 多线程将大文件分开下载后在合并的实例
Nov 09 Python
TensorFlow设置日志级别的几种方式小结
Feb 04 Python
Python+Appium实现自动化测试的使用步骤
Mar 24 Python
MAC平台基于Python Appium环境搭建过程图解
Aug 13 Python
PyCharm最新激活码PyCharm2020.2.3有效
Nov 18 Python
python 利用panda 实现列联表(交叉表)
Feb 06 Python
python 对xml解析的示例
Feb 27 Python
Django模型层实现多表关系创建和多表操作
Jul 21 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 adodb连接带密码access数据库实例,测试成功
2008/05/14 PHP
php pcntl_fork和pcntl_fork 的用法
2009/04/13 PHP
ionCube 一款类似zend的PHP加密/解密工具
2010/07/25 PHP
PHP防止表单重复提交的几种常用方法汇总
2014/08/19 PHP
php中current、next与reset函数用法实例
2014/11/17 PHP
PHP分享图片的生成方法
2018/04/25 PHP
php实现支付宝当面付(扫码支付)功能
2018/05/30 PHP
jquery 框架使用教程 AJAX篇
2009/10/11 Javascript
window.location.hash 使用说明
2010/11/08 Javascript
jquery异步调用页面后台方法‏(asp.net)
2011/03/01 Javascript
JavaScript中的公有、私有、特权和静态成员用法分析
2014/11/20 Javascript
Backbone.js的一些使用技巧
2015/07/01 Javascript
基于Jquery和html5实现炫酷的3D焦点图动画
2016/03/02 Javascript
IE下JS保存图片的简单实例
2016/07/15 Javascript
微信小程序页面开发注意事项整理
2017/05/18 Javascript
js学习总结_基于数据类型检测的四种方式(必看)
2017/07/04 Javascript
详谈表单重复提交的三种情况及解决方法
2017/08/16 Javascript
vue 自定义提示框(Toast)组件的实现代码
2018/08/17 Javascript
详解vue-cli@2.x项目迁移日志
2019/06/06 Javascript
Layer+Echarts构建弹出层折线图的方法
2019/09/25 Javascript
javascript 内存模型实例详解
2020/04/18 Javascript
[46:21]Liquid vs LGD 2018国际邀请赛淘汰赛BO3 第一场 8.23
2018/08/24 DOTA
python3中bytes和string之间的互相转换
2017/02/09 Python
python编程实现随机生成多个椭圆实例代码
2018/01/03 Python
python实现写数字文件名的递增保存文件方法
2018/10/25 Python
python-docx文件定位读取过程(尝试替换)
2020/02/13 Python
python中如何设置代码自动提示
2020/07/15 Python
python 利用zmail库发送邮件
2020/09/11 Python
详解Python中Pyyaml模块的使用
2020/10/08 Python
世界各地的旅游、观光和活动:Isango!
2019/10/29 全球购物
linux面试题参考答案(9)
2015/01/07 面试题
锦旗标语大全
2014/06/23 职场文书
大学奖学金获奖感言
2014/08/15 职场文书
庆祝教师节演讲稿
2014/09/03 职场文书
合作协议书模板2014
2014/09/26 职场文书
java开发双人五子棋游戏
2022/05/06 Java/Android