Ich möchte eine Möglichkeit zum Aktualisieren aller Felder in einem Word 2013-Dokument. (Wenn es in anderen Versionen funktioniert, umso besser. Ich hatte ursprünglich dieses Problem mit Word 2007, und seitdem scheint sich nichts geändert zu haben.) Dazu gehören Querverweise, Seitenzahlen, Inhaltsverzeichnisse, Indizes, Überschriften usw. Wenn es durch Drücken von aktualisiert werden kann F9, möchte ich es aktualisieren.
(Theoretisch kann das Aktualisieren von Feldern dazu führen, dass andere Felder aktualisiert werden müssen, z. B. ändert ein längeres Inhaltsverzeichnis einige Seitenzahlen im Haupttext. Das Aufpassen der üblichen Fälle ist gut genug für mich. Tatsächlich ist es in Ordnung, wenn ich ausführen muss das Makro zwei oder drei Mal, bevor es sich stabilisiert. Ich möchte nur ein einziges Makro haben, das alles findet.)
Bei meinem bisherigen Versuch werden Felder in Textfeldern in Zahlen nicht aktualisiert. Wie aktualisiere ich sie und was habe ich noch übersehen?
BEARBEITEN : Die Kombination der gegebenen Antwort mit dem, was ich bereits hatte, ergibt ein Makro, das alles zu aktualisieren scheint (mit einem bekannten Fehler ).
'' Update all the fields, indexes, etc. in the specified document.
Sub UpdateAllFieldsIn(doc As Document)
'' Update tables. We do this first so that they contain all necessary
'' entries and so extend to their final number of pages.
Dim toc As TableOfContents
For Each toc In doc.TablesOfContents
toc.Update
Next toc
Dim tof As TableOfFigures
For Each tof In doc.TablesOfFigures
tof.Update
Next tof
'' Update fields everywhere. This includes updates of page numbers in
'' tables (but would not add or remove entries). This also takes care of
'' all index updates.
Dim sr As range
For Each sr In doc.StoryRanges
sr.Fields.Update
While Not (sr.NextStoryRange Is Nothing)
Set sr = sr.NextStoryRange
'' FIXME: for footnotes, endnotes and comments, I get a pop-up
'' "Word cannot undo this action. Do you want to continue?"
sr.Fields.Update
Wend
Next sr
End Sub
'' Update all the fields, indexes, etc. in the active document.
'' This is a parameterless subroutine so that it can be used interactively.
Sub UpdateAllFields()
UpdateAllFieldsIn ActiveDocument
End Sub
Dim toa As Word.TableOfAuthorities / For Each toa In ActiveDocument.TablesOfAuthorities / toa.Update / Next