Work with Document Properties

Document properties allow some useful information to be stored along with the document. There is a system (built-in) and user-defined (custom) properties. Built-in properties contain such things as document title, author’s name, document statistics, and so on. Custom properties are just name-value pairs where the user defines both the name and value. You can use document properties in your document automation project to store some useful info along with the document such as when the document was received/processed/time stamped and so on. 

Accessing Document Properties in Microsoft Word

You can access document properties in Microsoft Word by using the File | Properties menu.


Accessing Document Properties in Aspose.Words

To access document properties in Aspose.Words do the following:

Document.BuiltInDocumentProperties returns a BuiltInDocumentProperties object and Document.CustomDocumentProperties returns a CustomDocumentProperties object. Both objects are collections of the DocumentProperty objects. These objects can be obtained through the indexer property either by name or by index. BuiltInDocumentProperties additionally provides access to the document properties via a set of typed properties that return values of the appropriate type. CustomDocumentProperties allows adding or removing document properties from the document. The following code example demonstrates how to enumerates through all built-in and custom properties in a document. You can download the template file of this example from here.

The DocumentProperty class allows you to get the name, value, and type of the document property:

  • To get the name of a property, use DocumentProperty.Name.
  • To get the value of a property, use DocumentProperty.Value. DocumentProperty.Value returns an Object, but there is a set of methods allowing you to get the value of the property converted to a particular type.
  • To get the type of a property, use DocumentProperty.Type. This returns one of the PropertyType enumeration values. After you get to know what type the property is, you can use one of the DocumentProperty.ToXXX methods such as DocumentProperty.ToString and DocumentProperty.ToInt to obtain the value of the appropriate type instead of getting DocumentProperty.Value.

Updating Built-In Document Properties

While Microsoft Word automatically updates some document properties when needed, Aspose.Words never automatically change any properties. For example, Microsoft Word updates the time the document was last printed, last saved, updates statistical properties (word, paragraph, character etc counts). Aspose.Words does not update any properties automatically but provides a method for updating some statistical built-in document properties. Call the Document.UpdateWordCount method to recalculate and update the BuiltInDocumentProperties.Characters , BuiltInDocumentProperties.CharactersWithSpaces , BuiltInDocumentProperties.Words and BuiltInDocumentProperties.Paragraphs properties in the BuiltInDocumentProperties collection. This will ensure they are synchronized with changes made after the document was opened or created.

Adding or Removing Document Properties

You cannot add or remove built-in document properties in Aspose.Words, you can only change their values. To add custom document properties in Aspose.Words, use CustomDocumentProperties.Add passing the name of the new property and the value of the appropriate type. The method returns the newly created DocumentProperty object. The following code example demonstrates how to checks if a custom property with a given name exists in a document and adds few more custom document properties. You can download the template file of this example from here.

To remove custom properties, use DocumentPropertyCollection.Remove passing it the name of the property to remove. The following code example demonstrates how to removes a custom document property.

Aspose.Words provides a method CustomDocumentProperties.AddLinkToContent(string, string) to create a new linked to content custom document property which returns the newly created property object or null if the link source is invalid. The following code example demonstrates how to configure the link to a content custom property.

Removing Personal Information from Document

If you want to share Word document with other people, you can remove personal information, such as author name and company. You can use the Document.RemovePersonalInformation property to set the flag indicating that Microsoft Word will remove all user information from comments, revisions and document properties upon saving the document. 

Setting this option does not actually remove personal information while a document is processed in Aspose.Words and affects only Microsoft Word behavior.

Getting Document Variables

You can get a collection of document variables using the Document.Variables property. Variable names and values are strings. The following code example demonstrates how to enumerate over document variables. You can download the template file of this example from here.

How to Convert Between Measurement Units

Most of the object properties provided in the Aspose.Words API that represent some measurement (width/height, margins and various distances) accept values in points (1 inch equals 72 points). Sometimes this is not convenient so there is the ConvertUtil class that provides helper functions to convert between various measurement units. It allows converting inches to points, points to inches, pixels to points, and points to pixels. When pixels are converted to points and vice versa, it can be performed at 96 dpi (dots per inch) resolutions or at the specified dpi resolution. ConvertUtil is very useful when setting different page properties because for instance inches are more usual measurement units than points. The following example demonstrates how to set up the page properties in inches. Below example shows how to specify page properties in inches.