Hoe kan ik alle velden in een Word-document updaten?
Ik wil een manier om alle velden in een Word 2013-document bij te werken. (Als het in andere versies werkt, is dat des te beter; ik had oorspronkelijk dit probleem met Word 2007, en sindsdien lijkt er niets te zijn veranderd). Dit omvat kruisverwijzingen, paginanummers, inhoudsopgaven, indexen, kopteksten, etc. Als het geüpdatet kan worden door op F9 te drukken, wil ik dat het geüpdatet wordt.
(In theorie kan het updaten van velden ervoor zorgen dat andere velden geüpdatet moeten worden, bijv. een langere inhoudsopgave verandert sommige paginanummers in de hoofdtekst. Het verzorgen van de gebruikelijke gevallen is goed genoeg voor mij. In feite is het oké als ik de macro twee of drie keer moet draaien voordat deze stabiliseert. Ik wil gewoon een enkele macro hebben die alles vindt.)
Mijn poging tot nu toe werkt geen velden in tekstvakken binnen de cijfers bij. Hoe kan ik ze updaten, en wat heb ik nog meer gemist?
- *
EDIT : De combinatie van het gegeven antwoord met wat ik al had geeft een macro die alles lijkt te updaten (met een bekend defect ).
'' 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