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中的decode()方法的使用
May 18 Python
python3 实现的人人影视网站自动签到
Jun 19 Python
python中import学习备忘笔记
Jan 24 Python
利用Django内置的认证视图实现用户密码重置功能详解
Nov 24 Python
使用pandas中的DataFrame数据绘制柱状图的方法
Apr 10 Python
python简单贪吃蛇开发
Jan 28 Python
关于pymysql模块的使用以及代码详解
Sep 01 Python
python实现猜数字游戏
Mar 25 Python
Python hashlib加密模块常用方法解析
Dec 18 Python
python中return的返回和执行实例
Dec 24 Python
python 制作网站筛选工具(附源码)
Jan 21 Python
Python3.8官网文档之类的基础语法阅读
Sep 04 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 获取全局变量的代码
2011/04/21 PHP
QQ互联一键登录审核不通过的解决方案
2014/09/10 PHP
php中simplexml_load_file函数用法实例
2014/11/12 PHP
PHP实现微信发红包程序
2015/08/24 PHP
php微信公众号开发之秒杀
2018/10/20 PHP
laravel 框架配置404等异常页面
2019/01/07 PHP
JavaScript 学习小结(适合新手参考)
2009/07/30 Javascript
JavaScript 10件让人费解的事情
2010/02/15 Javascript
js中关于new Object时传参的一些细节分析
2011/03/13 Javascript
javascript学习笔记(十一) 正则表达式介绍
2012/06/20 Javascript
js验证整数加保留小数点的简单实例
2013/12/02 Javascript
JS去掉字符串前后空格、阻止表单提交的实现代码
2017/06/08 Javascript
jQuery实现的点击按钮改变样式功能示例
2018/07/21 jQuery
微信小程序自定义轮播图
2018/11/04 Javascript
jQuery添加新内容的四个常用方法分析【append,prepend,after,before】
2019/03/19 jQuery
微信小程序日历弹窗选择器代码实例
2019/05/09 Javascript
vue-cli创建的项目中的gitHooks原理解析
2020/02/14 Javascript
[02:45]DOTA2英雄敌法师基础教程
2013/11/25 DOTA
[10:14]2018DOTA2国际邀请赛寻真——paiN Gaming不仅为自己而战
2018/08/14 DOTA
用Python计算三角函数之atan()方法的使用
2015/05/15 Python
玩转python爬虫之爬取糗事百科段子
2016/02/17 Python
Python的地形三维可视化Matplotlib和gdal使用实例
2017/12/09 Python
python素数筛选法浅析
2018/03/19 Python
使用python打印十行杨辉三角过程详解
2019/07/10 Python
Python学习笔记之文件的读写操作实例分析
2019/08/07 Python
opencv之颜色过滤只留下图片中的红色区域操作
2020/06/05 Python
HTML5 实现一个访问本地文件的实例
2012/12/13 HTML / CSS
英国知名化妆品网站:Revolution Beauty(原TAM Beauty)
2018/02/28 全球购物
教师推荐信范文
2013/11/24 职场文书
校园招聘策划书
2014/01/09 职场文书
高中生第一学年自我鉴定
2014/09/12 职场文书
个人务虚会发言材料
2014/10/20 职场文书
2015年青年志愿者工作总结
2015/05/20 职场文书
2015年国庆节标语大全
2015/07/30 职场文书
 Python 中 logging 模块使用详情
2022/03/03 Python
分析SQL窗口函数之取值窗口函数
2022/04/21 Oracle