Quiero una forma de actualizar todos los campos en un documento de Word 2013. (Si funciona en otras versiones, mucho mejor; originalmente tuve este problema con Word 2007, y nada parece haber cambiado desde entonces). Esto incluye referencias cruzadas, números de página, tablas de contenido, índices, encabezados, etc. Si se puede actualizar presionando F9, quiero que se actualice.
(En teoría, la actualización de campos puede hacer que otros campos necesiten actualización, por ejemplo, una tabla de contenido más larga cambia algunos números de página en el texto principal. Cuidar los casos comunes es lo suficientemente bueno para mí. De hecho, está bien si tengo que ejecutar la macro dos o tres veces antes de que se estabilice. Solo quiero tener una sola macro que encuentre todo).
Mi intento hasta ahora no actualiza los campos en los cuadros de texto dentro de las figuras. ¿Cómo los actualizo y qué más me he perdido?
EDITAR : Al combinar la respuesta dada con lo que ya tenía, se obtiene una macro que parece actualizar todo (con un defecto conocido ).
'' 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