Je veux un moyen de mettre à jour tous les champs dans un document Word 2013. (Si cela fonctionne dans d'autres versions, tant mieux; j'avais à l'origine ce problème avec Word 2007 et rien ne semble avoir changé depuis.) Cela comprend les références croisées, les numéros de page, les tables des matières, les index, les en-têtes, etc. S'il peut être mis à jour en appuyant sur F9, je veux qu'il soit mis à jour.
(En théorie, la mise à jour des champs peut nécessiter des mises à jour, par exemple une table des matières plus longue modifie certains numéros de page dans le texte principal. Prendre soin des cas courants me convient assez bien. En fait, je peux exécuter une tâche. la macro deux ou trois fois avant qu'elle ne se stabilise. Je veux juste avoir une seule macro qui trouve tout.)
Ma tentative jusqu'à présent ne met pas à jour les champs dans les zones de texte à l'intérieur des figures. Comment puis-je les mettre à jour et quoi d'autre ai-je manqué?
EDIT : En combinant la réponse donnée avec ce que j’avais déjà, on obtient une macro qui semble tout mettre à jour (avec un défaut connu ).
'' 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
la source
Dim toa As Word.TableOfAuthorities / For Each toa In ActiveDocument.TablesOfAuthorities / toa.Update / Next
Réponses:
Allez dans les paramètres d'impression, sélectionnez les champs de mise à jour. Ensuite, allez à imprimer ou à imprimer un aperçu de votre doc.
Et voilà, tous les champs sont mis à jour!
la source
Je fais juste Ctrl+ A- pour tout sélectionner - et ensuite F9 pour mettre à jour le lot.
Bien que cela manque des en-têtes et des pieds de page, mais ils sont mis à jour lorsque vous imprimez / affichez un aperçu avant impression.
Mise à jour
J'ai trouvé la macro suivante. Lors d'un test rapide, il a mis à jour des tables des matières, des champs dans des paragraphes, des champs dans l'en-tête et le pied de page et des champs dans une figure de zone de texte flottante.
Espérons que cela couvre tout ce dont vous avez besoin, sinon indiquez ce qui ne fonctionne toujours pas.
la source
NextStoryRange
et avecdocument.StoryRanges
sont deux choses différentes, mais votre code combiné avec les mises à jour de table que j'avais déjà constituait un gagnant (enfin, presque , mais c'est un problème différent).Cette page a l' air intéressante:
la source
Word 2010:
Cliquez avec le bouton droit sur le ruban, personnalisez-le, choisissez une commande dans "toutes les commandes", recherchez "mise à jour" et ajoutez-la à l'endroit souhaité.
Ce bouton met à jour uniquement les champs sélectionnés.
Ensuite, pour mettre à jour tous les champs, appuyez sur Ctrl+ Apuis sur le bouton.
la source
F9
? Est-ce que cela met vraiment à jour les chiffres, les tableaux, etc.?Si vous souhaitez mettre à jour correctement tous les en-têtes et les pieds de page, cela a fonctionné pour moi:
la source
Pour C #:
la source