使用poi将word转换为html,支持doc,docx,转换后可以保持图片、样式。
1.导入Maven包
org.apache.poi poi3.14 org.apache.poi poi-scratchpad3.14 org.apache.poi poi-ooxml3.14 fr.opensagres.xdocreport xdocreport1.0.6 org.apache.poi poi-ooxml-schemas3.14 org.apache.poi ooxml-schemas1.3
2.转换代码
import org.apache.poi.hwpf.HWPFdocument;
import org.apache.poi.hwpf.converter.WordToHtmlConverter;
import org.apache.poi.xwpf.converter.core.BasicURIResolver;
import org.apache.poi.xwpf.converter.core.FileImageExtractor;
import org.apache.poi.xwpf.converter.xhtml.XHTMLConverter;
import org.apache.poi.xwpf.converter.xhtml.XHTMLOptions;
import org.apache.poi.xwpf.usermodel.XWPFdocument;
import org.w3c.dom.document;
import javax.xml.parsers.documentBuilderFactory;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
public class Test {
// doc转换为html
void docToHtml() throws Exception {
String sourceFileName = "C:\doc\test.doc";
String targetFileName = "C:\html\test.html";
String imagePathStr = "C:\html\image\";
HWPFdocument worddocument = new HWPFdocument(new FileInputStream(sourceFileName));
document document = documentBuilderFactory.newInstance().newdocumentBuilder().newdocument();
WordToHtmlConverter wordToHtmlConverter = new WordToHtmlConverter(document);
// 保存图片,并返回图片的相对路径
wordToHtmlConverter.setPicturesManager((content, pictureType, name, width, height) -> {
try(FileOutputStream out = new FileOutputStream(imagePathStr + name)){
out.write(content);
} catch (Exception e) {
e.printStackTrace();
}
return "image/" + name;
});
wordToHtmlConverter.processdocument(worddocument);
document htmldocument = wordToHtmlConverter.getdocument();
DOMSource domSource = new DOMSource(htmldocument);
StreamResult streamResult = new StreamResult(new File(targetFileName));
TransformerFactory tf = TransformerFactory.newInstance();
Transformer serializer = tf.newTransformer();
serializer.setOutputProperty(OutputKeys.ENCODING, "utf-8");
serializer.setOutputProperty(OutputKeys.INDENT, "yes");
serializer.setOutputProperty(OutputKeys.METHOD, "html");
serializer.transform(domSource, streamResult);
}
// docx转换为html
public void docxToHtml() throws Exception {
String sourceFileName = "D:\ac\00.docx";
String targetFileName = "D:\ac\test.html";
String imagePathStr = "D:\ac\image\";
OutputStreamWriter outputStreamWriter = null;
try {
XWPFdocument document = new XWPFdocument(new FileInputStream(sourceFileName));
XHTMLOptions options = XHTMLOptions.create();
// 存放图片的文件夹
options.setExtractor(new FileImageExtractor(new File(imagePathStr)));
// html中图片的路径
options.URIResolver(new BasicURIResolver("image"));
outputStreamWriter = new OutputStreamWriter(new FileOutputStream(targetFileName), "utf-8");
XHTMLConverter xhtmlConverter = (XHTMLConverter) XHTMLConverter.getInstance();
xhtmlConverter.convert(document, outputStreamWriter, options);
} finally {
if (outputStreamWriter != null) {
outputStreamWriter.close();
}
}
}
演示地址: https://www.xiaoyun.studio/app/preview.html
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。



