python在word中插入目录和更新目录实现方式

 更新时间:2025年12月15日 15:08:51   作者:flashman911  
文章主要介绍了如何在Word文档中插入和更新目录,并提供了具体的代码示例,插入目录时,需要使用`TablesOfContents`对象,并设置使用默认样式、超链接和显示的最低层级,更新目录时,可以使用全部更新或只更新页码的方法

1、插入目录

需要用到对象:TablesOfContents

目录的集合对象是TablesOfContents,单个的对象是TableOfContents。这两个词看起来差不多,差别只在table的复数和单数的区别,当时看了很久才看出差别。

现在创建一个空白的文档,在文档中添加一级标题和二级标题,最后在文档最前面,插入生成的目录。

示例代码:

import win32com.client as win32
from win32com.client import constants

doc_app = win32.gencache.EnsureDispatch('Word.Application')
doc_app.Visible =1 #不设置的话,看不到应用程序界面
doc = doc_app.Documents.Add()

#添加标题1
##添加文字
parag = doc.Paragraphs.Add()
parag_range = parag.Range
parag_range.Text ='一级标题'
###设置样式
parag_range.Style = doc.Styles("标题 1")#Heading 1 是样式的名称

border = parag.Borders(constants.wdBorderBottom)
border.LineStyle = constants.wdLineStyleSingle
border.LineWidth = constants.wdLineWidth225pt

#添加标题2
parag_range.InsertParagraphAfter()#在当前位置之后,新插入一行
parag_range = parag.Range
parag_range.Text ='二级标题'
parag_range.Style = doc.Styles("标题 2")#二级标题
##添加正文
parag_range.InsertParagraphAfter()
parag_range = parag.Range
parag_range.Text ='正文'
parag_range.Style = doc.Styles("正文")#正文
##插入目录

doc.Paragraphs(1).Range.InsertParagraphBefore()#在首行之前插入一行,用于插入目录
parag_range = doc.Paragraphs(1).Range#指向新插入的行
#插入目录
##从当前指向的位置插入目录,使用默认样式设置目录样式,包含3级标题
doc.TablesOfContents.Add(Range=parag_range, UseHeadingStyles=True,LowerHeadingLevel=3, UseHyperlinks=True)

上述代码中,除了最后一行,其他的都是在填充word的内容。真正插入代码的功能,只有最后一行代码。

  • UseHeadingStyles:设置使用默认的style
  • UseHyperlinks:设置为Ture,则目录自带超链接。默认是False。
  • LowerHeadingLevel:设置目录显示的最低层级。通常UpperHeadingLevel不用设置。

生成效果:

对于文章中的段落的格式,例如间距、字体都可以通过手动设置在一个空白的word文档。

这个文档作为模板,自动生成的内容,可以直接使用其样式,这样效率更高。

2、更新目录

日常工作中经常还会遇到需要更新目录。

可以使用2种更新方法:全部更新(Update)和只更新页码(UpdatePageNumbers)

 只更新页码的示例代码:

for toc in doc.TablesOfContents: #遍历所有的目录对象
	toc.UpdatePageNumbers() # 更新页码

示例中,是遍历所有的目录对象。

如果需要针对特定的目录更新,可以使用doc.TablesOfContents(1)来制定首个目录,注意括号中的数字是从1开始的。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 如何使用python传入不确定个数参数

    如何使用python传入不确定个数参数

    这篇文章主要介绍了如何使用python传入不确定个数参数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • 浅谈对pytroch中torch.autograd.backward的思考

    浅谈对pytroch中torch.autograd.backward的思考

    这篇文章主要介绍了对pytroch中torch.autograd.backward的思考,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • Python提取频域特征知识点浅析

    Python提取频域特征知识点浅析

    在本文里我们给大家分享了关于Python提取频域特征的相关知识点以及基础内容,需要的朋友们跟着学习下。
    2019-03-03
  • Python数据分析之真实IP请求Pandas详解

    Python数据分析之真实IP请求Pandas详解

    这篇文章主要给大家介绍了Python数据分析之真实IP请求Pandas,文中通过示例嗲吗给大家介绍的很详细,相信对大家的学习或者理解具有一定的参考借鉴价值,有需要的朋友们可以参考借鉴,下面来一起学习学习吧。
    2016-11-11
  • Python中tkinter+MySQL实现增删改查

    Python中tkinter+MySQL实现增删改查

    这篇文章主要介绍了Python中tkinter+MySQL实现增删改查,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • python如何求解两数的最大公约数

    python如何求解两数的最大公约数

    这篇文章主要为大家详细介绍了python如何求解两数的最大公约数,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • Python进行WPS自动化的详细指南

    Python进行WPS自动化的详细指南

    由于 WPS 与 Microsoft Office 在接口上有一定的兼容性,可通过类似的技术实现自动化操作,但需注意 WPS 特有的 API 或限制,所以本文给大家介绍了Python进行WPS自动化的详操作指南,需要的朋友可以参考下
    2025-03-03
  • 对Python3 * 和 ** 运算符详解

    对Python3 * 和 ** 运算符详解

    今天小编就为大家分享一篇对Python3 * 和 ** 运算符详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-02-02
  • Python 实现图像特效中的油画效果

    Python 实现图像特效中的油画效果

    这篇文章主要是为大家简单介绍一下图像添加油画特效的基本原理以及代码实现,文中的示例代码很详细,对我们学习或者工作有一点的价值,感兴趣的小伙伴可以了解一下
    2021-12-12
  • Python3爬虫ChromeDriver的安装实例

    Python3爬虫ChromeDriver的安装实例

    在本篇文章里小编给大家整理的是一篇关于Python3爬虫ChromeDriver的安装实例内容,有兴趣的朋友们可以学习参考下。
    2021-02-02

最新评论