每个标题 2 下的 Table 内容 (TOC) 仅显示其副标题

A Table of Content (TOC) under each heading 2 showing only the subheadings thereof

我在超过 1000 页的 Word 文档中使用了 90 次标题 2。每个标题二都有许多副标题。最终目标是在每个标题 2 下添加一个单独的 Table Of Content (TOC),它仅显示该特定标题 2 下的子标题(排除标题 2 本身的文本,这本身可以通过限制TOC 至标题 3 及更小)。在网上搜索清楚,这并不像听起来那么简单。例如,TOC 选项中没有用于将 TOC 限制为下一个分节符的复选框,因此使用分节符来实现这一点毫无意义。唯一的方法似乎是为每个标题 2 下的所有文本添加单独的书签,并将目录代码限制为目录所在的相关书签。

我想不出一种方法来为每个标题 2 下的每个文本 selections 自动创建唯一命名的书签(例如在我的例子中是数字 1 到 90)。所以我愿意手动执行此操作。但如果不手动 select 每个标题 2.

下的所有文本,这已经是一种帮助

所以问题来了:哪个 VBA 代码可以帮助我解决这个 selection?或者您能想出一个在实现最终目标方面走得更远的代码吗?

最远的是找到一个标题2,在它前面加上两个不寻常的符号“£$”,转到下一个标题2做同样的事情等等。这里的想法是,一旦完成,我只需要在 $*£ 上使用通配符搜索 select 从标题 2 到下一个标题的文本。

但是我的代码一直在循环(当到达文档末尾时它从顶部重新开始),从今天开始它似乎不再工作了。而且,不可否认,也许整个方法有点蹩脚。尽管如此,我还是把代码贴在了底部。

非常感谢您的帮助,无论是通过改进我的代码,还是通过共享文档中下一个标题 2 下 selects 文本的其他代码(一个宏,然后我可以手动重复以继续在文档中创建手动书签)或找到更好的方法来实现每个标题 2 下单独目录的最终目标,仅显示该特定标题下的标题。

非常感谢。

威廉

Do While Selection.Find.Found = True
    
Selection.HomeKey Unit:=wdStory
        
Selection.Find.ClearFormatting
Selection.Find.Style = ActiveDocument.Styles("Kop 2")
With Selection.Find
    .Text = ""
    .Replacement.Text = ""
    .Forward = True
    .Wrap = wdFindContinue
    .Format = True
    .MatchCase = False
    .MatchWholeWord = False
    .MatchWildcards = False
    .MatchSoundsLike = False
    .MatchAllWordForms = False
End With
    Selection.Find.Execute

If Selection.Find.Found Then
    Selection.MoveLeft Unit:=wdCharacter, Count:=1

    Selection.TypeText Text:="$£"
    Selection.MoveDown Unit:=wdLine, Count:=4
End If

Loop

例如:

Sub AddHeading2TOCs()
Application.ScreenUpdating = False
Dim RngHd As Range, h As Long
With ActiveDocument.Range
  With .Find
    .ClearFormatting
    .Replacement.ClearFormatting
    .Text = ""
    .Replacement.Text = ""
    .Style = wdStyleHeading2
    .Format = True
    .Forward = True
    .Wrap = wdFindStop
  End With
  Do While .Find.Execute
    Set RngHd = .Paragraphs(1).Range: h = h + 1
    RngHd.InsertAfter vbCr
    Set RngHd = RngHd.GoTo(What:=wdGoToBookmark, Name:="\HeadingLevel")
    With RngHd
      .Paragraphs(2).Range.Style = wdStyleNormal
      .Start = .Paragraphs(2).Range.End
      .Bookmarks.Add "BkMkHd" & h, .Duplicate
      .Start = .Start - 1
      .Collapse wdCollapseStart
      .Fields.Add .Duplicate, wdFieldEmpty, "TOC \b BkMkHd" & h, False
    End With
    .Collapse wdCollapseEnd
  Loop
End With
Set RngHd = Nothing
Application.ScreenUpdating = True
End Sub