Python-docx查看表格样式技巧
时间:2026-01-27 15:45:39 498浏览 收藏
你在学习文章相关的知识吗?本文《Python-docx 查看所有表格样式方法》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

python-docx 默认模板内置了多种表格样式(如 'Table Grid'、'Light Shading' 等),但官方未提供直接枚举样式的 API;可通过遍历 `document.styles` 并筛选 `WD_STYLE_TYPE.TABLE` 类型样式,结合动态生成示例表格实现可视化预览。
在使用 python-docx 创建 Word 文档时,为表格应用美观统一的样式是提升文档专业性的关键一步。虽然文档中常直接写死样式名(如 table.style = 'Table Grid'),但开发者往往不清楚当前环境支持哪些表格样式——尤其当基于不同模板(如自定义 .dotx 文件)运行时,可用样式可能变化。
幸运的是,python-docx 的 Document 对象包含完整的样式库(doc.styles),我们可通过类型过滤提取全部表格样式,并逐一渲染示例表格以直观对比效果。以下是完整实现方案:
from docx import Document
from docx.enum.style import WD_STYLE_TYPE
from docx.shared import Pt
def list_table_styles_to_doc(output_path='available_table_styles.docx'):
doc = Document()
# 获取所有表格样式(按名称排序,提升可读性)
table_styles = [
style for style in doc.styles
if style.type == WD_STYLE_TYPE.TABLE
]
table_styles.sort(key=lambda s: s.name)
# 为每个样式添加标题和示例表格
for i, style in enumerate(table_styles, 1):
# 标题:样式序号 + 名称
doc.add_heading(f'{i}. "{style.name}"', level=2)
# 创建 2×3 示例表格
table = doc.add_table(rows=2, cols=3, style=style)
table.autofit = False
table.allow_autofit = False
# 设置固定列宽(避免自动缩放干扰视觉判断)
for cell in table.columns[0].cells:
cell.width = Pt(120)
for cell in table.columns[1].cells:
cell.width = Pt(80)
for cell in table.columns[2].cells:
cell.width = Pt(140)
# 填充表头与示例数据
hdr_cells = table.rows[0].cells
hdr_cells[0].text = 'Column A'
hdr_cells[1].text = 'Column B'
hdr_cells[2].text = 'Column C'
data_cells = table.rows[1].cells
data_cells[0].text = 'Data 1'
data_cells[1].text = 'Data 2'
data_cells[2].text = 'Data 3'
doc.save(output_path)
print(f"✅ 已生成包含 {len(table_styles)} 种表格样式的预览文档:{output_path}")
# 执行生成
list_table_styles_to_doc()⚠️ 注意事项:
- 此方法依赖于当前 Document() 实例所加载的默认模板(通常为 default.docx),若需测试自定义模板中的样式,请初始化时指定路径:Document('my_template.dotx');
- 部分样式名含空格或特殊字符(如 'Medium Shading 1 Accent 1'),务必严格匹配大小写与空格;
- doc.styles 中的样式对象可能包含 built_in=True 属性,但 python-docx 不区分内置/用户样式,统一通过 type 过滤即可;
- 若输出文档中某样式显示为默认无格式表格,说明该样式在当前模板中未正确定义(可能是占位符),建议优先选用文档中明确列出的 标准样式(如 'Table Grid', 'Light Shading', 'Medium List 1' 等)。
运行上述脚本后,将生成一个 .docx 文件,其中每种表格样式均配有清晰编号与结构一致的示例表格,便于快速比对、选择与复用。这是在缺乏 GUI 样式面板的编程环境中,最可靠、可复现的样式探索方式。
本篇关于《Python-docx查看表格样式技巧》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
408 收藏
-
289 收藏
-
271 收藏
-
422 收藏
-
119 收藏
-
315 收藏
-
223 收藏
-
460 收藏
-
232 收藏
-
410 收藏
-
339 收藏
-
310 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习