python-docx处理word文档(python如何处理word文档)
off999 2024-11-03 14:17 31 浏览 0 评论
前言
全网找了一番,用python创建和更新word(.docx)文档,还是 python-docx 包比较好用。
依赖
- Python 2.6, 2.7, 3.3, or 3.4
- lxml >= 2.3.2
安装模块
- 由于 python-docx 已经提交给 PyPI 仓库,所以可以使用 pip 安装,如下:
pip install python-docx
如果同时安装了 python2 和 python3 那么 pip 可能不能用,可以使用 pip3 来安装,如下:1Copypip3 install python-docxCopy如果同时安装了 python2 和 python3 那么 pip 可能不能用,可以使用 pip3 来安装,如下:
pip3 install python-docx- python-docx 也可以使用 easy_install 来安装,如下:
easy_install python-docx- 如果不能使用 pip 和 easy_install ,可以在 PyPI 下载包、解压、运行 setup.py ,如下:
tar xvzf python-docx-{version}.tar.gz
cd python-docx-{version}
python setup.py installpython-docx 还依赖 lxml 包 ,使用前2种方法会自动安装所需依赖包,第三种方法需要自己手动安装。
处理word文档
新建文档类
首先新建一个空白文档类 Document ,如下:
from docx import Document
document = Document()编辑已存在的word文档
python-docx 不仅可以创建word文档,还可以编辑已存在的word文档。
其实吧,这玩意儿只能编辑已存在的word文档,之所以有个“创建空白文档”的功能,只不过是拷贝一份空白word文档到工作区间,再在空白文档上编辑,看起来似乎是“创建空白文档”罢了。本质上还是编辑已存在的word文档,捂脸中…
打开一个word文档,编辑完后,一定要记得保存。如果保存文件名和原文件名不一样,则会另存为一份word文档;若文件名一样,则会不加提示的保存修改内容。如下:
from docx import Document
document = Document('existing-document-file.docx')
document.save('new-file-name.docx')新增段落
在word中 段落 是最常见的,创建段落 paragraph 的操作如下:
paragraph = document.add_paragraph('这是个段落。')在此段落之前插入一个段落,如下:
prior_paragraph = paragraph.insert_paragraph_before('这是前面的段落。')新增标题
新增标题代码如下:
document.add_heading('这是个标题')修改标题大小,有1-9种规格,如下:
document.add_heading('The role of dolphins', level=2)如果使用 level=0 ,则会新增一个带有下划线样式的标题。
新增分页符
代码如下:
document.add_page_break()新增表格
创建一个2行2列的表格 Table,如下:
table = document.add_table(rows=2, cols=2)获取第一行第二列的单元格类,如下:
cell = table.cell(0, 1)写入数据,如下:
cell.text = '这是第一行第二列的单元格'不仅如此,还能以数组的形式获取整个行或列,如下:
row = table.rows[1]
row.cells[0].text = '第二行第一列'
row.cells[1].text = '第二行第二列'或循环操作,如下:
for row in table.rows:
for cell in row.cells:
print(cell.text)用 len() 方法获取行数或列数,如下:
row_count = len(table.rows)
col_count = len(table.columns)增加行,如下:
row = table.add_row()设置表格样式,如下:
table.style = 'LightShading-Accent1'插入图片
插入本地图片,如下:
document.add_picture('demo.png')默认情况下,图片大小往往不尽如人意,调整图片大小,如下:
from docx.shared import Inches
document.add_picture('demo.png', width=Inches(1.0), height=Inches(1.0))若同时定义宽度和高度,则图片会被拉伸或压缩到指定大小;若仅定义宽度或高度,则图会自适应调整大小。所以,建议仅定义宽度即可。
段落操作
设置段落样式
设置段落样式,如下:
document.add_paragraph('这是一个样式为 ListBullet 的段落', style='ListBullet')或
paragraph = document.add_paragraph('这是一个样式为 ListBullet 的段落')
paragraph.style = 'List Bullet'设置段落对齐方式
段落对齐方式有 左对齐 、 文字居中 、 右对齐 、 文本两端对齐等,更多对齐方式请移步 WD_ALIGN_PARAGRAPH
from docx.enum.text import WD_ALIGN_PARAGRAPH
# LEFT => 左对齐
# CENTER => 文字居中
# RIGHT => 右对齐
# JUSTIFY => 文本两端对齐
paragraph = document.add_paragraph("你说啥")
paragraph_format = paragraph.paragraph_format
paragraph_format.alignment = WD_ALIGN_PARAGRAPH.CENTER设置段落缩进
设置段落缩进,可为负值,如下:
from docx.shared import Inches
paragraph = document.add_paragraph("你说啥")
paragraph_format = paragraph.paragraph_format
paragraph_format.left_indent = Inches(0.5)也可以设置首行缩进,如下:
paragraph_format.first_line_indent = Inches(-0.25)设置段落制表符
详情请移步 TabStops
设置段落间距
分为 段前 和 段后 ,设置值用 Pt 单位是 磅 ,如下:
paragraph_format.space_before = Pt(18)
paragraph_format.space_after = Pt(12)设置段落行距
当行距为 最小值 和 固定值 时,设置值单位为 磅 ,需要用 Pt ;当行距为 多倍行距 时,设置值为数值,如下:
from docx.shared import Length
#SINGLE => 单倍行距(默认)
#ONE_POINT_FIVE => 1.5倍行距
#DOUBLE2 => 倍行距
#AT_LEAST => 最小值
#EXACTLY => 固定值
#MULTIPLE => 多倍行距
paragraph.line_spacing_rule = WD_LINE_SPACING.EXACTLY #固定值
paragraph_format.line_spacing = Pt(18) # 固定值18磅
paragraph.line_spacing_rule = WD_LINE_SPACING.MULTIPLE #多倍行距
paragraph_format.line_spacing = 1.75 # 1.75倍行间距设置段落分页
- 孤行控制
防止在页面顶端单独打印段落末行或在页面底端单独打印段落首行。 - 与下段同页
防止在选中段落与后面一段间插入分页符。 - 段中不分页
防止在段落中出现分页符。 - 段前分页
在选中段落前插入分页符。
#widow_control => 孤行控制
#keep_with_next => 与下段同页
#page_break_before => 段前分页
#keep_together => 段中不分页
paragraph_format.keep_with_next = True
字体操作
设置粗体和斜体
在设置粗体和斜体之前,我们先简单了解一下 段落 里的运行机制。段落包含很多块级的格式,比如缩进、行高、制表符等。每一个小片段叫做一个 run ,可以对 run 设置粗体和斜体等属性。
我们可以设置如下:
paragraph = document.add_paragraph()
paragraph.add_run('这是一个带有')
paragraph.add_run('粗体').bold = True
paragraph.add_run('和')
paragraph.add_run('斜体').italic = True
paragraph.add_run('的段落。')设置字体属性
对 run 设置字体、大小、颜色下划线等,更多属性请移步 Font ,如下:
from docx.shared import RGBColor,Pt
# all_caps => 全部大写字母
# bold => 加粗
# color => 字体颜色
# complex_script => 是否为“复杂代码”
# cs_bold => “复杂代码”加粗
# cs_italic => “复杂代码”斜体
# double_strike => 双删除线
# emboss => 文本以凸出页面的方式出现
# hidden => 隐藏
# imprint => 印记
# italic => 斜体
# name => 字体
# no_proof => 不验证语法错误
# outline => 显示字符的轮廓
# shadow => 阴影
# small_caps => 小型大写字母
# snap_to_grid => 定义文档网格时对齐网络
# strike => 删除线
# subscript => 下标
# superscript => 上标
# underline => 下划线
paragraph = document.add_paragraph()
paragraph.add_run('这是一个带有')
paragraph.add_run('颜色').font.color.rgb = RGBColor(54, 95, 145)
paragraph.add_run('的')
paragraph.add_run('大字').font.size = Pt(36) # 字体大小设置,和word里面的字号相对应设置字符样式
除了设置段落样式外,还可以设置一组字符样式,比如字体、大小、颜色、粗体、斜体等,如下:
# 自定义样式 Emphasis
paragraph = document.add_paragraph('这是一个带有')
paragraph.add_run('自定义样式', 'Emphasis')
paragraph.add_run('的段落')或
paragraph = document.add_paragraph('这是一个带有 ')
run = paragraph.add_run('自定义样式')
run.style = 'Emphasis'
paragraph.add_run('的段落')页眉和页脚
更多内容请移步 Working with Headers and Footers
枚举的文档
- MSO_COLOR_TYPE
- MSO_THEME_COLOR_INDEX
- WD_PARAGRAPH_ALIGNMENT
- WD_BUILTIN_STYLE
- WD_CELL_VERTICAL_ALIGNMENT
- WD_COLOR_INDEX
- WD_LINE_SPACING
- WD_ORIENTATION
- WD_TABLE_ALIGNMENT
- WD_ROW_HEIGHT_RULE
- WD_SECTION_START
- WD_STYLE_TYPE
- WD_TAB_ALIGNMENT
- WD_TAB_LEADER
- WD_TABLE_DIRECTION
- WD_UNDERLINE
相关推荐
-
- 做图片的软件(做图片的软件app)
-
有手机版的p图大神可以制作好玩的图片此软件专门进行图片恶搞的,手机用美图秀秀,电脑上用ps推荐7个冷门APP吧,以上APP都是朋友推荐或自己无意间发现的,如有雷同,纯属意外。1.马卡龙玩图:马卡龙玩图是一款非常有趣的修图APP,强大的抠图功...
-
2026-01-18 17:15 off999
-
- 德国vs日本视频直播(德国vs日本视频直播回放)
-
世界杯直播德国与日本的比赛是在北京时间的11月23日21点这个时间段举行,这场比赛在卡塔尔世时间则是为16:00点。历史上德国和日本曾经有过2次交手,在2004年12月(日本0-3德国)和2006年5月(德国2-2日本)两队分别进行过2场友...
-
2026-01-18 17:03 off999
- 卡牌类手游排行榜第一名(卡牌类手游排行榜第一名是谁)
-
阴阳师忘川风华录神将三国姬斗无双天地劫:幽成再临月圆之夜阿比斯之旅黑潮之上山海镜花斗罗大陆:武魂觉醒以下是一拳超人手游中常见的卡牌排名:S级卡牌:1.一拳超人(变身)2.童帝(变身)3.杰诺斯A...
- 英雄联盟手游内测申请(英雄联盟手游内测申请地址)
-
要申请英雄联盟手游内测资格,您需要先安装好游戏并创建账号。然后根据游戏官方发布的内测申请指南,在指定时间内填写相应的申请表格。一般来说,申请表格会要求您填写以下信息:1.基本个人信息:包括姓名、年龄...
- 金色影视影视剧(金色影视 tv)
-
电影《金色池塘》拍摄地是英国南部新汉普郡。《金色池塘》是由马克·雷戴尔执导,凯瑟琳·赫本、亨利·方达等主演的剧情片。该片根据欧内斯特·汤普森的同名戏剧改编而成,讲述了年老的诺曼与女儿之间出现了感情危机...
- 下载全民k歌免费安装(找回《全民k歌》)
-
打开全民k歌网页版,打开想要下载的歌曲按F12,点击Network的选项,再按ctrl+R找到里面最大的文件,右键openlinkinnewtab新的页面中右键另存为,就可以下载了1.确保您的手机支...
- oa软件排行榜前十名(oa软件下载)
-
OA办公软件有很多,例如泛微、致远、蓝凌、华天动力、索昂、通达、飞企、微宏、万户、金和、今目标、协众、云之家、泛普、明道、天翎、手册类、安创安全OA、小熊OA等相对大型企业来说,中小型企业的管理规范...
- 免费下载优酷视频(优酷下载 安装)
-
首先,你要开通优酷VIP,不然很多电影都下载不了,其次就是打开手机上的优酷,找到自己想看的电影,点击进去,然后再播放页面,点击下面的下载按钮。选择下载版本的质量进行下载,有超清,高清,标清,然后返回到...
- qq恢复官网(QQ恢复官网网站)
-
打开浏览器,然后搜索QQ恢复官方网站,搜索到之后,点击进入;登录帐号,然后选择恢复QQ群,选择要恢复的群,点击确定即可。;注:只能用于找回最近28天内删除的群成员,以及解散、转让的群。如果误删的QQ群...
- 手机版英雄联盟(手机版英雄联盟有云顶之弈吗)
-
第一行是id号,也就是账号。第二行是密码。下面两个上到下分别是注册和忘记密码,方框里的是记住账号英雄联盟手游的版本可以通过游戏客户端上方的版本号及官方社交媒体平台上的公告来查看。版本号通常由一串数字和...
- gta5手机版免费下正版(gta5手机版免费下正版安卓gwa5)
-
官方貌似不支持下载游戏因为为正版貌似都是镜像版的希望帮到你正版游戏需要购买正版游戏盘的祝你游戏愉快!什么游戏都可以用修改器修改.不过前提是游戏公司没有限定,如果游戏公司在游戏中已经限定了那一...
-
- pdf阅读器永久免费版(pdf阅读器免费吗)
-
如果仅仅是阅读PDF文档的话。福星PDF阅读器就是永久免费版。美国的Adobereader也是PDF阅读器的永久免费版。PDF是一种专业的文档格式。它具有多种优势。很多专业的文献都通过PDF格式来保存。福星公司是中国优秀的PDF文档阅读...
-
2026-01-18 14:43 off999
- yy开播工具手机版(yy开播工具手机版官网)
-
想要将手机连接到YY开播,首先确保手机和电脑处于同一无线网络下,并且电脑已经安装了YY开播软件。在手机上下载并安装YY开播助手APP后,打开该应用并登录自己的YY账号。然后,在YY开播助手APP中选择...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
Python 批量卸载关联包 pip-autoremove
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
