文档在线预览(二)word、pdf、excel文件转html以实现文档在线预览

雨点打透心脏的1/2处 2024-03-16 15:58 201阅读 0赞

实现文档在线预览的方式除了上篇文章《文档在线预览(一)通过将txt、word、pdf转成图片实现在线预览功能》说的将文档转成图片的实现方式外,还有转成pdf,前端通过pdf.js、pdfobject.js等插件来实现在线预览,以及本文将要说到的将文档转成html的方式来实现在线预览。代码基于 aspose-words(用于word转html),pdfbox(用于pdf转html),所以事先需要在项目里下面两个依赖:

  1. <dependency>
  2. <groupId>com.luhuiguo</groupId>
  3. <artifactId>aspose-words</artifactId>
  4. <version>23.1</version></dependency>
  5. <dependency>
  6. <groupId>org.apache.pdfbox</groupId>
  7. <artifactId>pdfbox</artifactId>
  8. <version>2.0.4</version>
  9. </dependency>

一、将文件转换成html字符串

1、将word文件转成html字符串

  1. public static String wordToHtmlStr(String wordPath) {
  2. try {
  3. Document doc = new Document(wordPath); // Address是将要被转化的word文档
  4. String htmlStr = doc.toString();
  5. return htmlStr;
  6. } catch (Exception e) {
  7. e.printStackTrace();
  8. }
  9. return null;
  10. }

验证结果:

ee5f32a2f6470a28f089cef4cae3ac63.png

2、将pdf文件转成html字符串

  1. public static String pdfToHtmlStr(String pdfPath) throws IOException, ParserConfigurationException {
  2. PDDocument document = PDDocument.load(new File(pdfPath));
  3. Writer writer = new StringWriter();
  4. new PDFDomTree().writeText(document, writer);
  5. writer.close();
  6. document.close();
  7. return writer.toString();
  8. }

验证结果:

4d82cd2bbccd32c77106ac0029a306be.png

3、将excel文件转成html字符串

  1. public static String excelToHtmlStr(String excelPath) throws Exception {
  2. FileInputStream fileInputStream = new FileInputStream(excelPath);
  3. Workbook workbook = new XSSFWorkbook(fileInputStream);
  4. DataFormatter dataFormatter = new DataFormatter();
  5. FormulaEvaluator formulaEvaluator = workbook.getCreationHelper().createFormulaEvaluator();
  6. Sheet sheet = workbook.getSheetAt(0);
  7. StringBuilder htmlStringBuilder = new StringBuilder();
  8. htmlStringBuilder.append("<html><head><title>Excel to HTML using Java and POI library</title>");
  9. htmlStringBuilder.append("<style>table, th, td { border: 1px solid black; }</style>");
  10. htmlStringBuilder.append("</head><body><table>");
  11. for (Row row : sheet) {
  12. htmlStringBuilder.append("<tr>");
  13. for (Cell cell : row) {
  14. CellType cellType = cell.getCellType();
  15. if (cellType == CellType.FORMULA) {
  16. formulaEvaluator.evaluateFormulaCell(cell);
  17. cellType = cell.getCachedFormulaResultType();
  18. }
  19. String cellValue = dataFormatter.formatCellValue(cell, formulaEvaluator);
  20. htmlStringBuilder.append("<td>").append(cellValue).append("</td>");
  21. }
  22. htmlStringBuilder.append("</tr>");
  23. }
  24. htmlStringBuilder.append("</table></body></html>");
  25. return htmlStringBuilder.toString();
  26. }

返回的html字符串:

  1. <html><head><title>Excel to HTML using Java and POI library</title><style>table, th, td { border: 1px solid black; }</style></head><body><table><tr><td>序号</td><td>姓名</td><td>性别</td><td>联系方式</td><td>地址</td></tr><tr><td>1</td><td>张晓玲</td><td></td><td>11111111111</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>2</td><td>王小二</td><td></td><td>1222222</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>1</td><td>张晓玲</td><td></td><td>11111111111</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>2</td><td>王小二</td><td></td><td>1222222</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>1</td><td>张晓玲</td><td></td><td>11111111111</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>2</td><td>王小二</td><td></td><td>1222222</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>1</td><td>张晓玲</td><td></td><td>11111111111</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>2</td><td>王小二</td><td></td><td>1222222</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>1</td><td>张晓玲</td><td></td><td>11111111111</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>2</td><td>王小二</td><td></td><td>1222222</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>1</td><td>张晓玲</td><td></td><td>11111111111</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>2</td><td>王小二</td><td></td><td>1222222</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>1</td><td>张晓玲</td><td></td><td>11111111111</td><td>上海市浦东新区xx路xx弄xx号</td></tr><tr><td>2</td><td>王小二</td><td></td><td>1222222</td><td>上海市浦东新区xx路xx弄xx号</td></tr></table></body></html>

二、将文件转换成html,并生成html文件

有时我们是需要的不仅仅返回html字符串,而是需要生成一个html文件这时应该怎么做呢?一个改动量小的做法就是使用org.apache.commons.io包下的FileUtils工具类写入目标地址:

FileUtils类将html字符串生成html文件示例:

首先需要引入pom:

  1. <dependency>
  2. <groupId>commons-io</groupId>
  3. <artifactId>commons-io</artifactId>
  4. <version>2.8.0</version>
  5. </dependency>

相关代码:

  1. String htmlStr = FileConvertUtil.pdfToHtmlStr("D:\\书籍\\电子书\\小说\\历史小说\\最后的可汗.doc");
  2. FileUtils.write(new File("D:\\test\\doc.html"), htmlStr, "utf-8");

除此之外,还可以对上面的代码进行一些调整,已实现生成html文件,代码调整如下:

1、将word文件转换成html文件

  1. public static void wordToHtml(String wordPath, String htmlPath) {
  2. try {
  3. File sourceFile = new File(wordPath);
  4. String path = htmlPath + File.separator + sourceFile.getName().substring(0, sourceFile.getName().lastIndexOf(".")) + ".html";
  5. File file = new File(path); // 新建一个空白pdf文档
  6. FileOutputStream os = new FileOutputStream(file);
  7. Document doc = new Document(wordPath); // Address是将要被转化的word文档
  8. HtmlSaveOptions options = new HtmlSaveOptions();
  9. options.setExportImagesAsBase64(true);
  10. options.setExportRelativeFontSize(true);
  11. doc.save(os, options);
  12. } catch (Exception e) {
  13. e.printStackTrace();
  14. }
  15. }

word原文件效果:

42e6b888196762dda39fabbb2c02b0dc.png

word文件转换成html效果:

63a2df0344c18a9b61834f4688f88e50.png

2、将pdf文件转换成html文件

  1. public static void pdfToHtml(String pdfPath, String htmlPath) throws IOException, ParserConfigurationException {
  2. File file = new File(pdfPath);
  3. String path = htmlPath + File.separator + file.getName().substring(0, file.getName().lastIndexOf(".")) + ".html";
  4. PDDocument document = PDDocument.load(new File(pdfPath));
  5. Writer writer = new PrintWriter(path, "UTF-8");
  6. new PDFDomTree().writeText(document, writer);
  7. writer.close();
  8. document.close();
  9. }

图片版PDF文件验证结果:

a10499106bb756b921257edf513fa2f4.png

文字版PDF原文件效果:

d936ba0ef8204ace008d32181b5b6716.png

文字版PDF文件验证结果:

ebc0633e83a510ae8ab4471d0ac2eeb9.png

3、将excel文件转换成html文件

  1. public static void excelToHtml(String excelPath, String htmlPath) throws Exception {
  2. String path = FileUtil.getNewFileFullPath(excelPath, htmlPath, "html");
  3. try(FileOutputStream fileOutputStream = new FileOutputStream(path)){
  4. String htmlStr = excelToHtmlStr(excelPath);
  5. byte[] bytes = htmlStr.getBytes();
  6. fileOutputStream.write(bytes);
  7. }
  8. }

excel原文件效果:

5cfdbf68fa9030c3f9b9671d193f034f.png

excel文件转换成html文件验证效果:

32d534e52853987d0e47b8ec840db5af.png

总结

从上述的效果展示我们可以发现其实转成html效果不是太理想,很多细节样式没有还原,这其实是因为这类转换往往都是追求目标是通过使用文档中的语义信息并忽略其他细节来生成简单干净的 HTML,所以在转换过程中复杂样式被忽略,比如居中、首行缩进、字体,文本大小,颜色。举个例子在转换是 会将应用标题 1 样式的任何段落转换为 h1 元素,而不是尝试完全复制标题的样式。所以转成html的显示效果往往和原文档不太一样。这意味着对于较复杂的文档而言,这种转换不太可能是完美的。但如果都是只使用简单样式文档或者对文档样式不太关心的这种方式也不妨一试。

发表评论

表情:
评论列表 (有 0 条评论,201人围观)

还没有评论,来说两句吧...

相关阅读

    相关 文件在线

    浏览器并不能支持word、excel文件的在线预览,所以都是将word、excel转换为浏览器能直接看的文件格式(html、pdf、txt、png、svg、flash),因此在