Как конвертировать HTML <h3> </h3> в документ MS Heading3 в Docx4j? - PullRequest
0 голосов
/ 21 мая 2019

Я генерировал документ Word из содержимого HTML.

, используя приведенный ниже код.

ordprocessingMLPackage wordMLPackage = WordprocessingMLPackage.createPackage(PageSizePaper.LETTER, false);

XHTMLImporterImpl XHTMLImporter = new XHTMLImporterImpl(wordMLPackage);
XHTMLImporter.setRunFormatting(FormattingOption.CLASS_PLUS_OTHER);
NumberingDefinitionsPart ndp = new NumberingDefinitionsPart();

wordMLPackage.getMainDocumentPart().addTargetPart(ndp);
ndp.unmarshalDefaultNumbering();

wordMLPackage.getMainDocumentPart().getContent().addAll(XHTMLImporter.convert("<h3> SAMPLE HEADING</h3>", null));

File exportFile = new File(somepath/sample.docx);
wordMLPackage.save(exportFile);

Выше код работает нормально и генерирует документ, но HTML <h3> SAMPLE HEADING</h3> не делает 't преобразуется в MS word Заголовок 3 , он отображается как обычный текст в документе.

Позже я сгенерирую оглавление TOC , используя эти заголовки, используя приведенный ниже код.

tocGenerator.generateToc( 1,    "TOC \\o \"1-3\" \\h \\z \\u ", false);

Однако этот код не поддерживает нормальный текст для генерации оглавления.

1 Ответ

1 голос
/ 29 мая 2019

Нам нужно изменить настройку заголовка, используя следующий код.

ImportXHTMLProperties.setProperty("docx4j-ImportXHTML.Element.Heading.MapToStyle", true);

Здесь обновленный код, который работает для требования.

//  activating Headings property for MS Word Heading Mapping
ImportXHTMLProperties.setProperty("docx4j-ImportXHTML.Element.Heading.MapToStyle", true);
ordprocessingMLPackage wordMLPackage = WordprocessingMLPackage.createPackage(PageSizePaper.LETTER, false);

XHTMLImporterImpl XHTMLImporter = new XHTMLImporterImpl(wordMLPackage);
XHTMLImporter.setRunFormatting(FormattingOption.CLASS_PLUS_OTHER);
NumberingDefinitionsPart ndp = new NumberingDefinitionsPart();

wordMLPackage.getMainDocumentPart().addTargetPart(ndp);
ndp.unmarshalDefaultNumbering();

wordMLPackage.getMainDocumentPart().getContent().addAll(XHTMLImporter.convert("<h3> SAMPLE HEADING</h3>", null));

File exportFile = new File(somepath/sample.docx);
// adding TOC - TABLE OF CONTENTS
TocGenerator tocGenerator = new TocGenerator(wordMLPackage);
tocGenerator.generateToc(0, "TOC \\o \"1-3\" \\h \\z \\u ", false);

wordMLPackage.save(exportFile);
...