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 相关文章推荐
PyChar学习教程之自定义文件与代码模板详解
Jul 17 Python
python3获取两个日期之间所有日期,以及比较大小的实例
Apr 08 Python
Matplotlib 生成不同大小的subplots实例
May 25 Python
python初学者,用python实现基本的学生管理系统(python3)代码实例
Apr 10 Python
Django框架orM与自定义SQL语句混合事务控制操作
Jun 27 Python
解决Pytorch训练过程中loss不下降的问题
Jan 02 Python
通过实例解析Python RPC实现原理及方法
Jul 07 Python
pytorch使用horovod多gpu训练的实现
Sep 09 Python
python 利用matplotlib在3D空间绘制二次抛物面的案例
Feb 06 Python
python实现学生信息管理系统源码
Feb 22 Python
python基础之模块的导入
Oct 24 Python
python如何为list实现find方法
May 30 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
多文件上载系统完整版
2006/10/09 PHP
php无限极分类实现的两种解决方法
2013/04/28 PHP
单点登录 Ucenter示例分析
2013/10/29 PHP
php防止sql注入代码实例
2013/12/18 PHP
ThinkPHP的cookie和session冲突造成Cookie不能使用的解决方法
2014/07/01 PHP
使用WordPress发送电子邮件的相关PHP函数用法解析
2015/12/15 PHP
javascript css float属性的特殊写法
2008/11/13 Javascript
php实例分享之实现显示网站运行时间
2014/05/20 Javascript
JS通过Cookie判断页面是否为首次打开
2016/02/05 Javascript
JavaScript实现移动端滑动选择日期功能
2016/06/21 Javascript
jQuery事件绑定用法详解
2016/09/08 Javascript
jQuery实现弹出窗口弹出div层的实例代码
2017/01/09 Javascript
微信小程序 监听手势滑动切换页面实例详解
2017/06/15 Javascript
Vue.js分页组件实现:diVuePagination的使用详解
2018/01/10 Javascript
使用Angular CLI进行单元测试和E2E测试的方法
2018/03/24 Javascript
vue2.0 实现导航守卫(路由守卫)
2018/05/21 Javascript
vue.js的vue-cli脚手架中使用百度地图API的实例
2019/01/21 Javascript
JS把字符串格式的时间转换成几秒前、几分钟前、几小时前、几天前等格式
2019/07/10 Javascript
JS中的算法与数据结构之队列(Queue)实例详解
2019/08/20 Javascript
vue项目中使用多选框的实例代码
2020/07/22 Javascript
swiperjs实现导航与tab页的联动
2020/12/13 Javascript
[01:22:28]DOTA2-DPC中国联赛 正赛 SAG vs RNG BO3 第一场 1月18日
2021/03/11 DOTA
python实现连接mongodb的方法
2015/05/08 Python
使用python画个小猪佩奇的示例代码
2018/06/06 Python
使用python将大量数据导出到Excel中的小技巧分享
2018/06/14 Python
对Python3 * 和 ** 运算符详解
2019/02/16 Python
Python基于scipy实现信号滤波功能
2019/05/08 Python
keras 特征图可视化实例(中间层)
2020/01/24 Python
基于SpringBoot构造器注入循环依赖及解决方式
2020/04/26 Python
你需要学会的8个Python列表技巧
2020/06/24 Python
高二英语教学反思
2014/01/19 职场文书
小学开学寄语
2014/01/19 职场文书
企业宗旨标语
2014/06/10 职场文书
关于运动会广播稿200字
2014/10/08 职场文书
2015年社会实践个人总结
2015/03/06 职场文书
vue3使用vue-router的完整步骤记录
2021/06/20 Vue.js