Saved searches

Use saved searches to filter your results more quickly

Cancel Create saved search Sign up Reseting focus

You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session. You switched accounts on another tab or window. Reload to refresh your session.

Convert Word documents to simple and clean HTML

License

Notifications You must be signed in to change notification settings

mwilliamson/java-mammoth

This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.

Go to file

Folders and files

Last commit message Last commit date

Latest commit

History

View all files

Repository files navigation

Mammoth .docx to HTML converter for Java/JVM

Installation

dependency> groupId>org.zwobble.mammothgroupId> artifactId>mammothartifactId> version>1.8.0version> dependency>

Other supported platforms

Usage

Library

Basic conversion

To convert an existing .docx file to HTML, create an instance of DocumentConverter and pass an instance of File to convertToHtml . For instance:

import org.zwobble.mammoth.DocumentConverter; import org.zwobble.mammoth.Result; DocumentConverter converter = new DocumentConverter(); ResultString> result = converter.convertToHtml(new File("document.docx")); String html = result.getValue(); // The generated HTML SetString> warnings = result.getWarnings(); // Any warnings during conversion

You can also extract the raw text of the document by using extractRawText . This will ignore all formatting in the document. Each paragraph is followed by two newlines.

DocumentConverter converter = new DocumentConverter(); ResultString> result = converter.extractRawText(new File("document.docx")); String html = result.getValue(); // The raw text SetString> warnings = result.getWarnings(); // Any warnings during conversion

Custom style map

By default, Mammoth maps some common .docx styles to HTML elements. For instance, a paragraph with the style name Heading 1 is converted to a h1 element. You can add custom style maps by calling addStyleMap(String) . A description of the syntax for style maps can be found in the section "Writing style maps". For instance, if paragraphs with the style name Section Title should be converted to h1 elements, and paragraphs with the style name Subsection Title should be converted to h2 elements:

DocumentConverter converter = new DocumentConverter() .addStyleMap("p[style-name='Section Title'] => h1:fresh") .addStyleMap("p[style-name='Subsection Title'] => h2:fresh");

You can also pass in the entire style map as a single string, which can be useful if style maps are stored in text files:

String styleMap = "p[style-name='Section Title'] => h1:fresh\n" + "p[style-name='Subsection Title'] => h2:fresh"; DocumentConverter converter = new DocumentConverter() .addStyleMap(styleMap);

The most recently-added styles have the greatest precedence. User-defined style mappings are used in preference to the default style mappings. To stop using the default style mappings altogether, call disableDefaultStyleMap :

DocumentConverter converter = new DocumentConverter() .disableDefaultStyleMap();

Custom image handlers

By default, images are converted to elements with the source included inline in the src attribute. This behaviour can be changed by calling imageConverter() with an image converter .

For instance, the following would replicate the default behaviour:

DocumentConverter converter = new DocumentConverter() .imageConverter(image -> < String base64 = streamToBase64(image::getInputStream); String src = "data:" + image.getContentType() + ";base64," + base64; MapString, String> attributes = new HashMap<>(); attributes.put("src", src); return attributes; >);

where streamToBase64 is a function that reads an input stream and encodes it as a Base64 string.

Bold

By default, bold text is wrapped in tags. This behaviour can be changed by adding a style mapping for b . For instance, to wrap bold text in tags:

DocumentConverter converter = new DocumentConverter() .addStyleMap("b => em");

Italic

By default, italic text is wrapped in tags. This behaviour can be changed by adding a style mapping for i . For instance, to wrap italic text in tags:

DocumentConverter converter = new DocumentConverter() .addStyleMap("i => strong");

Underline

By default, the underlining of any text is ignored since underlining can be confused with links in HTML documents. This behaviour can be changed by adding a style mapping for u . For instance, suppose that a source document uses underlining for emphasis. The following will wrap any explicitly underlined source text in tags:

DocumentConverter converter = new DocumentConverter() .addStyleMap("u => em");

Strikethrough

By default, strikethrough text is wrapped in tags. This behaviour can be changed by adding a style mapping for strike . For instance, to wrap strikethrough text in tags:

DocumentConverter converter = new DocumentConverter() .addStyleMap("strike => del");

Comments

By default, comments are ignored. To include comments in the generated HTML, add a style mapping for comment-reference . For instance:

DocumentConverter converter = new DocumentConverter() .addStyleMap("comment-reference => sup");

Comments will be appended to the end of the document, with links to the comments wrapped using the specified style mapping.

API

DocumentConverter

Result

Represents the result of a conversion. Methods:

Image converters

An image converter can be created by implementing ImageConverter.ImgElement . This creates an element for each image in the original docx. The interface has a single method, Map convert(Image image) . The image argument is the image element being converted, and has the following methods:

convert() should return a Map of attributes for the element. At a minimum, this should include the src attribute. If any alt text is found for the image, this will be automatically added to the element's attributes.

For instance, the following replicates the default image conversion:

DocumentConverter converter = new DocumentConverter() .imageConverter(image -> < String base64 = streamToBase64(image::getInputStream); String src = "data:" + image.getContentType() + ";base64," + base64; MapString, String> attributes = new HashMap<>(); attributes.put("src", src); return attributes; >);

where streamToBase64 is a function that reads an input stream and encodes it as a Base64 string.

Writing style maps

A style map is made up of a number of style mappings separated by new lines. Blank lines and lines starting with # are ignored.

A style mapping has two parts:

When converting each paragraph, Mammoth finds the first style mapping where the document element matcher matches the current paragraph. Mammoth then ensures the HTML path is satisfied.

Freshness

When writing style mappings, it's helpful to understand Mammoth's notion of freshness. When generating, Mammoth will only close an HTML element when necessary. Otherwise, elements are reused.

For instance, suppose one of the specified style mappings is p[style-name='Heading 1'] => h1 . If Mammoth encounters a .docx paragraph with the style name Heading 1 , the .docx paragraph is converted to a h1 element with the same text. If the next .docx paragraph also has the style name Heading 1 , then the text of that paragraph will be appended to the existing h1 element, rather than creating a new h1 element.

In most cases, you'll probably want to generate a new h1 element instead. You can specify this by using the :fresh modifier:

p[style-name='Heading 1'] => h1:fresh

The two consecutive Heading 1 .docx paragraphs will then be converted to two separate h1 elements.

Reusing elements is useful in generating more complicated HTML structures. For instance, suppose your .docx contains asides. Each aside might have a heading and some body text, which should be contained within a single div.aside element. In this case, style mappings similar to p[style-name='Aside Heading'] => div.aside > h2:fresh and p[style-name='Aside Text'] => div.aside > p:fresh might be helpful.