✍️ Python 批量设置 Word 文档多级字体样式(标题/正文/名称/小节)

本文展示如何利用 python-docx 为大量 Word 文档自动设置符合规范的字体格式------

  • 标题使用方正小标宋

  • 姓名、部门、日期使用楷体

  • 正文使用仿宋

  • 一级标题黑体,二级标题楷体

  • 支持批量处理整个文件夹中的 Word,输出到新的目标文件夹

适合公文排版、规范报告、美化文件等日常办公场景。


🎯 核心思路

  1. 定义专属字体样式函数:F_title, F_name_dept, F_main, F_title1, F_title2

  2. 批量读取指定目录下所有 .docx 文件

  3. 逐文档处理:遍历段落,对不同层级结构段落应用不同样式

  4. 按原文件名保存至目标目录 已处理文件


🛠️ 字体样式函数定义

python 复制代码
from docx.shared import Pt
from docx.oxml.ns import qn

def F_title(run):
    run.font.size = Pt(22)
    run.bold = True
    run.font.name = "方正小标宋_GBK"
    run._element.rPr.rFonts.set(qn("w:eastAsia"), "方正小标宋_GBK")

def F_name_dept(run):
    run.font.size = Pt(17)
    run.bold = False
    run.font.name = "楷体"
    run._element.rPr.rFonts.set(qn("w:eastAsia"), "楷体")

def F_main(run):
    run.font.size = Pt(17)
    run.bold = False
    run.font.name = "仿宋"
    run._element.rPr.rFonts.set(qn("w:eastAsia"), "仿宋")

def F_title1(run):
    run.font.size = Pt(17)
    run.bold = False
    run.font.name = "黑体"
    run._element.rPr.rFonts.set(qn("w:eastAsia"), "黑体")

def F_title2(run):
    run.font.size = Pt(17)
    run.bold = True
    run.font.name = "楷体"
    run._element.rPr.rFonts.set(qn("w:eastAsia"), "楷体")

🔄 批量处理多文件逻辑

python 复制代码
import docx, os

path = '待处理文件'
files = [os.path.join(path, f) for f in os.listdir(path)]

for file in files:
    doc = docx.Document(file)
    # 第一段为总标题
    for run in doc.paragraphs[0].runs:
        F_title(run)
    # 第二、三段为姓名、部门、日期
    for para in doc.paragraphs[1:3]:
        for run in para.runs:
            F_name_dept(run)

    title1_marks = ["一、","二、","三、","四、"]
    title2_marks = ["1、","2、","3、","4、"]

    for para in doc.paragraphs[3:]:
        if any(mark in para.text for mark in title1_marks):
            for run in para.runs:
                F_title1(run)
        elif any(mark in para.text for mark in title2_marks):
            for run in para.runs:
                F_title2(run)
        else:
            for run in para.runs:
                F_main(run)

    out_path = os.path.join('已处理文件', os.path.basename(file))
    doc.save(out_path)
  • 第一段为主标题,第二三段为姓名部门,再往下根据"标记符"区分不同层级段落;

  • 支持格式自动套用,不用手动修改每段文字。


🖼️ 结果展示区


✅ 注意事项 & 技术说明

  • 中文字体需与 Windows 安装字体保持一致名称,否则设置无效 ;

  • 需导入 qn 方法将中文字体写入 w:eastAsia 标签,保证兼容 Word 中文渲染;

  • Pt() 方法设定磅值,根据文档规范可自定义字号;

  • 建议先备份原文件,再保存结果到 已处理文件 文件夹。


🧭 拓展建议

  • ✅ 动态识别更多层级标题,例如"(一)、(二)...";

  • ✅ 支持文档末尾"参考文献""附件"自动添加页眉页脚信息;

  • ✅ 结合之前表格样式处理脚本,自动格式 Word 中表格单元格;

  • ✅ GUI 界面支持字体选择及批处理路径一键操作。

更多实用案例,代码,素材如下:

自取链接:https://pan.quark.cn/s/a46f30accea2


📝 总结

你现在拥有了一个强大的批量 Word 文档排版工具,只需轻松拖入文档即可一键套用统一字体样式。不论是公司报告,还是多份会议纪要,都可以实现美观规范的自动排版。如果需要进一步定制样式或元素,欢迎继续提需求!

相关推荐
Python×CATIA工业智造4 分钟前
Pycaita二次开发基础代码解析:几何体重命名与参数提取技术
python·pycharm·pycatia
你的电影很有趣31 分钟前
lesson30:Python迭代三剑客:可迭代对象、迭代器与生成器深度解析
开发语言·python
成成成成成成果3 小时前
揭秘动态测试:软件质量的实战防线
python·功能测试·测试工具·测试用例·可用性测试
瓶子xf3 小时前
Excel制作滑珠图、哑铃图
excel
天天进步20153 小时前
Python游戏开发引擎设计与实现
开发语言·python·pygame
数据狐(DataFox)4 小时前
CTE公用表表达式的可读性与性能优化
经验分享·python·sql
蹦蹦跳跳真可爱5894 小时前
Python----MCP(MCP 简介、uv工具、创建MCP流程、MCP客户端接入Qwen、MCP客户端接入vLLM)
开发语言·人工智能·python·语言模型
No0d1es4 小时前
第13届蓝桥杯Python青少组中/高级组选拔赛(STEMA)2022年1月22日真题
python·青少年编程·蓝桥杯·选拔赛
MediaTea4 小时前
Python 库手册:getopt Unix 风格参数解析模块
服务器·开发语言·python·unix
王尼莫啊4 小时前
【立体标定】圆形标定板标定python实现
开发语言·python·opencv