Chcę sposobu aktualizacji wszystkich pól w dokumencie Word 2013. (Jeśli działa w innych wersjach, tym lepiej; pierwotnie miałem ten problem z programem Word 2007 i od tego czasu wydaje się, że nic się nie zmieniło). Obejmuje to odsyłacze, numery stron, spis treści, indeksy, nagłówki itp. Jeśli można to zaktualizować naciskając F9, chcę to zaktualizować.
(Teoretycznie aktualizacja pól może powodować konieczność aktualizacji innych pól, np. Dłuższy spis treści zmienia niektóre numery stron w tekście głównym. Dbanie o typowe przypadki jest dla mnie wystarczające. Właściwie to dobrze, jeśli muszę uruchomić makro dwa lub trzy razy, zanim się ustabilizuje. Chcę tylko jedno makro, które wszystko znajdzie.)
Moja dotychczasowa próba nie aktualizuje pól w polach tekstowych wewnątrz rysunków. Jak je zaktualizować i czego jeszcze mi brakowało?
EDYCJA : Połączenie odpowiedzi udzielonej z tym, co już miałem, daje makro, które wydaje się aktualizować wszystko (ze znaną wadą ).
'' 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