Normalerweise enthält ein in Microsoft Word eingefügtes Feld bereits einen aktuellen Wert. Wenn es sich bei dem Feld beispielsweise um eine Formel oder eine Seitenzahl handelt, enthält es den korrekten berechneten Wert für die angegebene Version des Dokuments. Wenn Sie jedoch über eine Anwendung verfügen, die ein Dokument mit Feldern generiert oder ändert, z. B. zwei Dokumente zusammenführen oder mit Daten füllen, müssen im Idealfall alle Felder aktualisiert werden, damit das Dokument nützlich ist.
So aktualisieren Sie Felder
Wenn ein Dokument geladen wird, ahmt Aspose.Words das Verhalten von Microsoft Word nach, wobei die Option zum automatischen Aktualisieren von Feldern ausgeschaltet ist. Das Verhalten lässt sich wie folgt zusammenfassen:
- Wenn Sie ein Dokument öffnen/speichern, bleiben die Felder erhalten
- Sie können bei Bedarf alle Felder in einem Dokument explizit aktualisieren, z. B.
TOC
neu erstellen - Wenn Sie in PDF oder XPS drucken/rendern, werden die Felder für die Seitennummerierung in Kopf-/Fußzeilen aktualisiert
- Wenn Sie mail merge ausführen, werden alle Felder automatisch aktualisiert
Aktualisieren Sie Felder programmgesteuert
Um Felder im gesamten Dokument explizit zu aktualisieren, rufen Sie einfach die UpdateFields-Methode auf. Um in einem Dokument enthaltene Felder zu aktualisieren, rufen Sie ein Range-Objekt ab und rufen Sie die UpdateFields-Methode auf. In Aspose.Words können Sie mithilfe der Node.Range-Eigenschaft einen Range-Code für jeden Knoten im Dokumentbaum abrufen, z. B. Section, HeaderFooter, Paragraph usw. Sie können das Ergebnis eines einzelnen Felds aktualisieren, indem Sie die Methode Update aufrufen.
Automatische Aktualisierung seitenbezogener Felder während des Renderns
Wenn Sie die Konvertierung eines Dokuments in ein festes Seitenformat durchführen, z. B. in PDF oder XPS, aktualisiert Aspose.Words automatisch die seitenlayoutbezogenen Felder PAGE
und PAGEREF
in den Kopf-/Fußzeilen des Dokuments. Dieses Verhalten ahmt das Verhalten von Microsoft Word beim Drucken eines Dokuments nach.
Wenn Sie alle anderen Felder im Dokument aktualisieren möchten, müssen Sie UpdateFields aufrufen, bevor Sie das Dokument rendern.
Das folgende Codebeispiel zeigt, wie alle Felder vor dem Rendern eines Dokuments aktualisiert werden:
Automatische Feldaktualisierung während Mail Merge
Wenn Sie ein mail merge ausführen, werden alle Felder im Dokument automatisch aktualisiert. Dies liegt daran, dass es sich bei mail merge um eine Feldaktualisierung handelt. Das Programm stößt auf ein mail merge-Feld und muss dessen Ergebnis aktualisieren. Dazu muss der Wert aus der Datenquelle abgerufen und in das Feld eingefügt werden. Die Logik ist natürlich komplizierter. Wenn beispielsweise das Ende des Dokument-/mail merge-Bereichs erreicht ist, aber noch weitere Daten zusammengeführt werden müssen, muss der Bereich dupliziert und der neue Satz von Feldern aktualisiert werden.
Aktualisieren Sie Felder mit fehlerhaften Attributen
“w:dirty” ist ein Attribut auf Feldebene, das beim Öffnen des Dokuments nur das von Ihnen angegebene Feld aktualisiert. Es weist MS Word an, dieses Feld erst beim nächsten Öffnen des Dokuments zu aktualisieren. Mithilfe der UpdateDirtyFields-Eigenschaft können Sie angeben, ob die Felder mit dem Dirty-Attribut aktualisiert werden sollen. Wenn der Wert von UpdateDirtyFields auf true festgelegt ist, werden alle Felder mit true-Werten für die Field.IsDirty- oder FieldChar.IsDirty-Eigenschaft beim Laden des Dokuments aktualisiert.
Das folgende Codebeispiel zeigt, wie Felder mit dem Dirty-Attribut aktualisiert werden:
Aktualisieren Sie die LastSavedTime-Eigenschaft vor dem Speichern
Mithilfe der UpdateLastSavedTimeProperty-Eigenschaft können Sie festlegen, ob beim Speichern des Dokuments die entsprechende integrierte Dokumenteigenschaft LastSavedTime aktualisiert werden soll.
Das folgende Codebeispiel zeigt, wie diese Eigenschaft aktualisiert wird: