Wie aktualisiere ich alle Felder in einem Word-Dokument?


97

Ich möchte eine Möglichkeit zum Aktualisieren aller Felder in einem Word 2013-Dokument. (Wenn es in anderen Versionen funktioniert, umso besser. Ich hatte ursprünglich dieses Problem mit Word 2007, und seitdem scheint sich nichts geändert zu haben.) Dazu gehören Querverweise, Seitenzahlen, Inhaltsverzeichnisse, Indizes, Überschriften usw. Wenn es durch Drücken von aktualisiert werden kann F9, möchte ich es aktualisieren.

(Theoretisch kann das Aktualisieren von Feldern dazu führen, dass andere Felder aktualisiert werden müssen, z. B. ändert ein längeres Inhaltsverzeichnis einige Seitenzahlen im Haupttext. Das Aufpassen der üblichen Fälle ist gut genug für mich. Tatsächlich ist es in Ordnung, wenn ich ausführen muss das Makro zwei oder drei Mal, bevor es sich stabilisiert. Ich möchte nur ein einziges Makro haben, das alles findet.)

Bei meinem bisherigen Versuch werden Felder in Textfeldern in Zahlen nicht aktualisiert. Wie aktualisiere ich sie und was habe ich noch übersehen?


BEARBEITEN : Die Kombination der gegebenen Antwort mit dem, was ich bereits hatte, ergibt ein Makro, das alles zu aktualisieren scheint (mit einem bekannten Fehler ).

'' 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

1
Der Vollständigkeit halber möchten Sie möglicherweise auch die Tabelle der Behörden hinzufügen: Dim toa As Word.TableOfAuthorities / For Each toa In ActiveDocument.TablesOfAuthorities / toa.Update / Next
Terrance

Nur ein Hinweis, dass ich dies in Word 2013 ausprobiert und bestätigt habe, dass es immer noch funktioniert. Vielen Dank @Gilles für die Bereitstellung des Codes!
Ugo

Was ist mit einem Makro, das die Vorschau druckt und zum Dokument zurückkehrt?
Pedro77

@ Pedro77 Wie soll das helfen? Zumindest mit Word 2013 (ich habe keinen Zugriff mehr auf Word 2007) werden beim Drucken in der Vorschau oder beim Drucken keine Felder aktualisiert.
Gilles

Meine Felder werden aktualisiert, zumindest Referenzen und Querverweisfelder.
Pedro77

Antworten:


37

Gehen Sie in die Druckeinstellungen und wählen Sie Felder aktualisieren. Gehen Sie dann zum Drucken, oder drucken Sie eine Vorschau Ihres Dokuments.

Et voilà, alle Felder werden aktualisiert!

MS Word-Druckoptionen von Word of Mac 2016


2
Arbeitet jetzt für mich in Word 2010 (die Einstellung befindet sich unter „Datei → Optionen → Anzeige“). In der Tat werden ohne die Option einige Felder aktualisiert, aber nicht alle. Ich bin mir ziemlich sicher, dass es nicht in Word 2007 war, aber ich muss es nicht mehr testen.
Gilles

2
Ich bin auf Word 2016 für Mac. Die Einstellung ist in Word -> Einstellungen -> Drucken. Aber bei Witwen wird es im Druckbereich der globalen Einstellungen angezeigt. Ich bin mir sicher, dass ich in der Vergangenheit dort gewesen bin, aber ich habe momentan keine Installation zum Testen.
David Roussel

Ich denke, das funktioniert in Word 2016 nicht mehr.
TCB13

Dies funktionierte für mich in Word 2016 unter Windows 7.
27.

Funktioniert nicht in Word 2016 Windows. Felder in z. B. Fußzeilen werden nicht korrekt aktualisiert.
Hobbes

80

Ich mache einfach Ctrl+ A- um alles auszuwählen - und dann F9 das Los zu aktualisieren.

Hier fehlen zwar Kopf- und Fußzeilen, sie werden jedoch aktualisiert, wenn Sie IIRC drucken / als Druckvorschau anzeigen.


Aktualisieren

Ich habe das folgende Makro gefunden. Bei einem kurzen Test wurden Inhaltsverzeichnisse, Felder in Absätzen, Felder in der Kopf- und Fußzeile und Felder in einer schwebenden Textfeldfigur aktualisiert.

Hoffentlich deckt das alles ab, was Sie brauchen, wenn nicht, geben Sie bitte an, was immer noch nicht aktualisiert werden kann.

Quelle: http://www.gmayor.com/installing_macro.htm

Sub UpdateAll()
    Dim oStory As Range
    For Each oStory In ActiveDocument.StoryRanges
        oStory.Fields.Update
        If oStory.StoryType <> wdMainTextStory Then
            While Not (oStory.NextStoryRange Is Nothing)
                Set oStory = oStory.NextStoryRange
                oStory.Fields.Update
            Wend
        End If
    Next oStory
    Set oStory = Nothing
End Sub

@Giles - Okay, fair genug, prüfen Sie am besten zuerst, ob die Grundlagen erforscht wurden. Ich war gerade auf der Jagd und habe ein Makro gefunden, das den Job zu erledigen scheint. Überprüfe mein Update und lass es mich wissen, wenn etwas fehlt.
DMA57361

Jetzt reden wir! Ich habe keine Ahnung, warum das Iterieren mit NextStoryRangeund mit document.StoryRangesunterschiedlichen Dingen ist, aber Ihr Code in Kombination mit den Tabellenaktualisierungen, die ich bereits hatte, ist ein Gewinner (na ja, fast , aber das ist ein anderes Problem).
Gilles

Dies funktioniert nicht für Felder in Textfeldern in der Kopf- / Fußzeile. Überprüft auf Word 2016
Slobo

5

Diese Seite sieht interessant aus:

Wenn Sie Word 2007 verwenden, ist der Vorgang etwas anders: Klicken Sie auf die Office-Schaltfläche und dann auf Word-Optionen. Word zeigt das Dialogfeld Word-Optionen an. Klicken Sie links im Dialogfeld auf Erweitert. (Klicken Sie hier, um eine verwandte Abbildung anzuzeigen.) Vergewissern Sie sich, dass im Bereich Allgemein (etwas nach unten scrollen, um sie anzuzeigen) das Kontrollkästchen Automatische Verknüpfungen beim Öffnen aktualisieren aktiviert ist. Klicken Sie auf OK. Diese Einstellung sollte sicherstellen, dass alle Ihre Links immer auf dem neuesten Stand sind. Wenn Sie die Felder beim Öffnen des Dokuments aktualisieren möchten, müssen Sie ein Makro verwenden, um die Aufgabe auszuführen. Insbesondere müssen Sie entweder ein AutoOpen- oder ein AutoClose-Makro verwenden, je nachdem, ob Sie die Felder beim Öffnen oder Schließen des Dokuments aktualisieren möchten. Das folgende Beispiel zeigt ein AutoOpen-Makro, das Sie verwenden können.

Sub AutoOpen()
    With Options
        .UpdateFieldsAtPrint = True
        .UpdateLinksAtPrint = True
    End With
    ActiveDocument.Fields.Update
End Sub

Beachten Sie, dass der Makro sicherstellt, dass die Optionen so eingestellt sind, dass die Aktualisierung der Felder und Verknüpfungen beim Drucken erzwungen wird. Anschließend werden alle Mitglieder der Fields-Auflistung im Dokument aktualisiert. Wenn Sie stattdessen die Felder beim Schließen aktualisieren möchten, können Sie das folgende Makro verwenden:

Sub AutoClose()
    ActiveDocument.Fields.Update
End Sub

Dieses Makro ist viel kürzer, da beim Verlassen des Dokuments keine Optionen zum Aktualisieren beim Drucken festgelegt werden müssen.


4

Word 2010:

Klicken Sie mit der rechten Maustaste auf die Multifunktionsleiste, passen Sie die Multifunktionsleiste an, wählen Sie den Befehl aus "Alle Befehle", suchen Sie nach "Aktualisieren" und fügen Sie ihn an der gewünschten Stelle hinzu.

Diese Schaltfläche aktualisiert nur ausgewählte Felder.
Drücken Sie dann Ctrl+ und Adann diese Taste , um alle Felder zu aktualisieren .


Wie unterscheidet es sich vom Pressen F9? Wird das in Abbildungen, Tabellen usw. wirklich aktualisiert?
Gilles

1
Ich habe jetzt Word 2013, also habe ich nachgesehen. Dies entspricht anscheinend dem Drücken von F9. Felder in Zahlen werden nicht aktualisiert, was meine Hauptmotivation war, diese Frage zu stellen.
Gilles

3

Wenn Sie alle Kopf- und Fußzeilen korrekt aktualisieren möchten, hat dies bei mir funktioniert:

    Dim oStory As Range
    Dim oSection As Object
    Dim oHeader As Object
    Dim oFooter As Object

    For Each oStory In ActiveDocument.StoryRanges
        oStory.Fields.Update
    Next oStory

        For Each oSection In ActiveDocument.Sections
             For Each oHeader In oSection.Headers
                 oHeader.Range.Fields.Update
             Next oHeader

             For Each oFooter In oSection.Footers
                 oFooter.Range.Fields.Update
             Next oFooter
        Next oSection

Wie verbessert sich die akzeptierte Antwort ? Aktualisiert es Felder in Textfeldern in Zahlen?
Gilles,

2

Für C #:

using System;
using System.Collections.Generic;
using System.IO;
using Microsoft.Office.Interop.Word;

class Program
{
    static void Main(string[] args)
    {
        List<string> path = new List<string>(args);

        string filePathstr = string.Join(" ", path.ToArray());
        //System.Windows.Forms.MessageBox.Show("filepathstr: " + filePathstr);

        string folderPathstr = Path.GetDirectoryName(filePathstr);
        //System.Windows.Forms.MessageBox.Show("folderPathstr: " + folderPathstr);

        try
        {
            Application ap = new Application();
            Document document = ap.Documents.Open(filePathstr);
            document.Fields.Update();

            foreach (Section section in document.Sections)
            {
                document.Fields.Update();  // update each section

                HeadersFooters headers = section.Headers;  //Get all headers
                foreach (HeaderFooter header in headers)
                {
                    Fields fields = header.Range.Fields;
                    foreach (Field field in fields)
                    {
                        field.Update();  // update all fields in headers
                    }
                }

                HeadersFooters footers = section.Footers;  //Get all footers
                foreach (HeaderFooter footer in footers)
                {
                    Fields fields = footer.Range.Fields;
                    foreach (Field field in fields)
                    {
                        field.Update();  //update all fields in footers
                    }
                }
            }    

            document.Save();
            document.Close();

        }
        catch (NullReferenceException)
        {
            System.Windows.Forms.MessageBox.Show("A valid file was not selected.");
        }
    }
}
Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.