docx4j is an open source (Apache v2) library for creating, editing, and saving OpenXML "packages", including docx, pptx, and xslx.
It uses JAXB to create the Java representation.
- Open existing docx/pptx/xlsx
- Create new docx/pptx/xlsx
- Programmatically manipulate docx/pptx/xlsx (anything the file format allows)
- CustomXML binding (with support for pictures, rich text, checkboxes, and OpenDoPE extensions for repeats & conditionals, and importing XHTML)
- Export as HTML
- Export as PDF (using Plutext's PDF Converter, or use docx4j-export-FO project)
- Produce/consume Word 2007's xmlPackage (pkg) format
- Apply transforms, including common filters
- Font support (font substitution, and use of any fonts embedded in the document)
Get it from GitHub, at https://github.com/plutext/docx4j For more details, see https://www.docx4java.org/blog/2015/06/docx4j-from-github-in-eclipse-5-years-on/
If you are working with the source code, please join the developer mailing list:
https://www.docx4java.org/downloads.html
See the Getting Started guide: https://github.com/plutext/docx4j/tree/master/docs
and the Cheat Sheet: https://www.docx4java.org/blog/2013/05/docx4j-in-a-single-page/
And see the sample code: https://github.com/plutext/docx4j/tree/master/src/samples
You'll probably want the Helper AddIn to generate code: https://www.docx4java.org/blog/2016/05/docx4j-helper-word-addin-new-version-v3-3-0/
https://www.docx4java.org/forums or StackOverflow (use tag 'docx4j')
Please post to one or the other, not both
docx4j is published under the Apache License version 2.0. For the license text, please see the following files in the legals directory:
- LICENSE
- NOTICE Legal information on libraries used by docx4j can be found in the "legals/NOTICE" file.