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中处理unchecked未捕获异常实例
Jan 17 Python
Python实现中文数字转换为阿拉伯数字的方法示例
May 26 Python
Python基于numpy灵活定义神经网络结构的方法
Aug 19 Python
python实现xlsx文件分析详解
Jan 02 Python
pycharm 将python文件打包为exe格式的方法
Jan 16 Python
关于python字符串方法分类详解
Aug 20 Python
python网络爬虫 Scrapy中selenium用法详解
Sep 28 Python
pytorch 修改预训练model实例
Jan 18 Python
运行tensorflow python程序,限制对GPU和CPU的占用操作
Feb 06 Python
python 成功引入包但无法正常调用的解决
Mar 09 Python
Linux安装Python3如何和系统自带的Python2并存
Jul 23 Python
python tkinter的消息框模块(messagebox,simpledialog)
Nov 07 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 使用post,get的一种简洁方式
2010/04/25 PHP
php 中英文语言转换类代码
2011/08/11 PHP
深入php define()函数以及defined()函数的用法详解
2013/06/05 PHP
PHP实现重载的常用方法实例详解
2017/10/18 PHP
PHP实现的ID混淆算法类与用法示例
2018/08/10 PHP
php微信扫码支付 php公众号支付
2019/03/24 PHP
JS实现从表格中动态删除指定行的方法
2015/03/31 Javascript
jQuery中text() val()和html()的区别实例详解
2016/06/28 Javascript
详解vue中computed 和 watch的异同
2017/06/30 Javascript
Javascript调试之console对象——你不知道的一些小技巧
2017/07/10 Javascript
JavaScript仿微信(电话)联系人列表滑动字母索引实例讲解(推荐)
2017/08/16 Javascript
React Native 真机断点调试+跨域资源加载出错问题的解决方法
2018/01/18 Javascript
jQuery实现模糊查询的方法分析
2018/05/10 jQuery
解决vuejs项目里css引用背景图片不能显示的问题
2018/09/13 Javascript
javascript设计模式 ? 代理模式原理与用法实例分析
2020/04/16 Javascript
vue实现简易计算器功能
2021/01/20 Vue.js
[01:12]快闪回顾DOTA2亚洲邀请赛(DAC) 静候2018新征程开启
2018/03/11 DOTA
Python实现的监测服务器硬盘使用率脚本分享
2014/11/07 Python
python实现文本去重且不打乱原本顺序
2016/01/26 Python
深入理解python中的select模块
2017/04/23 Python
python3 pandas 读取MySQL数据和插入的实例
2018/04/20 Python
详解python配置虚拟环境
2019/04/08 Python
python 申请内存空间,用于创建多维数组的实例
2019/12/02 Python
tensorflow实现残差网络方式(mnist数据集)
2020/05/26 Python
Python绘图实现台风路径可视化代码实例
2020/10/23 Python
python实现计算图形面积
2021/02/22 Python
Ray-Ban雷朋美国官网:全球领先的太阳眼镜品牌
2016/07/20 全球购物
Myprotein法国官网:欧洲第一运动营养品牌
2019/03/26 全球购物
牵手50新加坡:专为黄金岁月的单身人士而设的交友网站
2020/08/16 全球购物
大学生个人实习的自我评价
2014/02/15 职场文书
服装设计专业求职信
2014/06/16 职场文书
八一建军节演讲稿
2014/09/10 职场文书
2014年大班保育员工作总结
2014/12/02 职场文书
网聊搭讪开场白
2015/05/28 职场文书
爱国主义电影观后感
2015/06/18 职场文书
python利用pandas分析学生期末成绩实例代码
2021/07/09 Python