Saya ingin cara memperbarui semua bidang dalam dokumen Word 2013. (Jika berfungsi di versi lain, semuanya lebih baik; Saya awalnya memiliki masalah dengan Word 2007, dan sepertinya tidak ada yang berubah sejak saat itu.) Ini termasuk referensi silang, nomor halaman, daftar isi, indeks, header, dll. Jika itu dapat diperbarui dengan menekan F9, saya ingin itu diperbarui.
(Dalam bidang pembaruan teori dapat menyebabkan bidang lain perlu diperbarui, misalnya daftar isi yang lebih panjang mengubah beberapa nomor halaman dalam teks utama. Merawat kasus umum cukup baik untuk saya. Bahkan, tidak apa-apa jika saya harus menjalankan makro dua atau tiga kali sebelum stabil. Saya hanya ingin memiliki satu makro yang menemukan segalanya.)
Upaya saya sejauh ini tidak memperbarui bidang dalam kotak teks di dalam angka. Bagaimana cara saya memperbaruinya, dan apa lagi yang saya lewatkan?
EDIT : Menggabungkan jawaban yang diberikan dengan apa yang sudah saya miliki memberikan makro yang tampaknya memperbarui semuanya (dengan cacat yang diketahui ).
'' 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