"The file contains custom XML elements which are no longer supported by Word" when you try to open a document in Word
Office 365 ProPlus is being renamed to Microsoft 365 Apps for enterprise. For more information about this change, read this blog post.
Consider the following scenario. You try to open a document in Microsoft Office Word 2007, in Microsoft Word 2010 or in Microsoft Word 2013 that is using one of the following file formats:
- Word Document (.DOCX)
- Word Macro-Enabled Document (.DOCM)
- Word Template (.DOTX)
- Word Macro-Enabled Template (.DOTM)
- Word XML Document (.XML)
- Word 2003 XML Document (.XML)
During the opening process for Word 2007, for Word 2010 or for Word 2013, you receive the following error message:
The file contains custom XML elements which are no longer supported by Word. If you save this file, these custom XML elements will be removed permanently.
Then when you click OK, the custom XML elements don't display.
Microsoft Word 2013 displays the error message for the following file formats in addition to the file formats previously listed:
- Word 97-2003 Document (.DOC)
- Word Web Pages (.HTML)
- Rich Text Format (.RTF)
Versions of Word that are distributed by Microsoft after January 10, 2010 no longer read the custom XML markup that may be contained within .DOCX, .DOCM, .DOTX, .DOTM or .XML files. The new versions of Word 2007, Word 2010 and Word 2013 can still open these files, but any custom XML markup is removed.
Custom XML markup in a Word document is visible as pink (the default color) tag names surrounding text in a document:
The removal of custom XML markup is the result of a United States court ruling on December 22, 2009. Generally, customers who purchase or license Word 2007, Word 2010 or Word 2013 from Microsoft after January 10, 2010 for use in the United States and its territories have to use updated software that does not include a particular custom XML tagging implementation.
The following features of Word are not affected by the update.
Content controls are not affected. Content controls are a common method of structuring document content and mapping content to custom XML parts.
Open XML standards (all ECMA and ISO versions) are not affected.
Custom XML markup that is stored within Word 97-2003 document (.DOC) files is not affected.
Ribbon XML and Ribbon Extensibility are not affected.
Custom XML Parts are not affected. For more information about custom XML Parts, see Custom XML parts overview.
The Word object model is not affected. However, some object model methods that deal with custom XML markup may produce different results.
- The TransformDocument method will continue to work, but any custom XML markup within the results of the transform will be removed.
- The InsertXML method will continue to work, but any custom XML markup that is present will be removed before the content is inserted.
If you are a developer of a solution that uses custom XML markup, be aware that support for custom XML markup is no longer available. Many of the scenarios implemented by using custom XML markup can be implemented by using alternative technologies, such as content controls, form fields, and bookmarks which are available in Word 2007, Word 2010 and Word 2013. For example, as explained in the following articles, content controls (in addition to these other technologies such as bookmarks) enable developers to create structured documents and can be used to assign arbitrary values to structured content. These arbitrary values can be used to assign semantic meaning to parts of your content.
For more information about content controls, visit the following Microsoft webpages:
- Creating Word 2007 Templates Programmatically
- Building Word 2007 Document Templates Using Content Controls
- Mapping Word 2007 Content Controls to Custom XML Using the XMLMapping Object
- How to: Bind a Content Control to a Node in the Data Store
- Taking Advantage of Bound Content Controls
- The Easy Way to Assemble Multiple Word Documents
- Creating Data-Bound Content Controls using the Open XML SDK and LINQ to XML