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抓取京东商城手机列表url实例代码
Dec 18 Python
python字符串加密解密的三种方法分享(base64 win32com)
Jan 19 Python
Python之inspect模块实现获取加载模块路径的方法
Oct 16 Python
Django使用unittest模块进行单元测试过程解析
Aug 02 Python
Python Pandas对缺失值的处理方法
Sep 27 Python
python实现输入的数据在地图上生成热力图效果
Dec 06 Python
python中安装django模块的方法
Mar 12 Python
keras得到每层的系数方式
Jun 15 Python
python使用QQ邮箱实现自动发送邮件
Jun 22 Python
Spring @Enable模块驱动原理及使用实例
Jun 23 Python
Python实现树莓派摄像头持续录像并传送到主机的步骤
Nov 30 Python
Python爬虫基础之爬虫的分类知识总结
May 13 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
多人战的战术与战略
2020/03/04 星际争霸
PHP时间戳与日期之间转换的实例介绍
2013/04/19 PHP
PHP实现长文章分页实例代码(附源码)
2016/02/03 PHP
PHP实现可自定义样式的分页类
2016/03/29 PHP
微信公众号判断用户是否已关注php代码解析
2016/06/24 PHP
页面只能打开一次Cooike如何实现
2012/12/04 Javascript
用jquery实现点击栏目背景色改变
2012/12/10 Javascript
node.js中的fs.mkdir方法使用说明
2014/12/17 Javascript
JavaScript编程中的Promise使用大全
2015/07/28 Javascript
JS中的二叉树遍历详解
2016/03/18 Javascript
基于JS+Canves实现点击按钮水波纹效果
2016/09/15 Javascript
微信小程序 icon组件详细及实例代码
2016/10/25 Javascript
微信小程序获取手机号授权用户登录功能
2017/11/09 Javascript
微信小程序scroll-view组件实现滚动动画
2018/01/31 Javascript
浅谈angularJS2中的界面跳转方法
2018/08/31 Javascript
浅谈React之状态(State)
2018/09/19 Javascript
解决vuejs 使用value in list 循环遍历数组出现警告的问题
2018/09/26 Javascript
vue读取本地的excel文件并显示在网页上方法示例
2019/05/29 Javascript
Python中列表和元组的使用方法和区别详解
2020/12/30 Python
Python基于回溯法子集树模板解决旅行商问题(TSP)实例
2017/09/05 Python
Flask解决跨域的问题示例代码
2018/02/12 Python
python实现读Excel写入.txt的方法
2018/04/29 Python
python爬虫正则表达式之处理换行符
2018/06/08 Python
django如何连接已存在数据的数据库
2018/08/14 Python
用Python中的turtle模块画图两只小羊方法
2019/04/09 Python
Python实现html转换为pdf报告(生成pdf报告)功能示例
2019/05/04 Python
Python之NumPy(axis=0 与axis=1)区分详解
2019/05/27 Python
Python3.5以上版本lxml导入etree报错的解决方案
2019/06/26 Python
python3实现网页版raspberry pi(树莓派)小车控制
2020/02/12 Python
CSS3 伪类选择器 nth-child()说明
2010/07/10 HTML / CSS
汽车技术服务与营销专业在籍生自荐信
2013/09/28 职场文书
教育科研先进个人材料
2014/01/26 职场文书
小学生国庆演讲稿
2014/09/05 职场文书
公司离职证明样本
2014/09/13 职场文书
2015年营业员工作总结
2015/04/23 职场文书
python Polars库的使用简介
2021/04/21 Python