freemarker填充ftl格式转PDF三页问题 documents4j 实现Word文档、xlsx、等格式转换PDF文件

导入依赖:

        implementation 'com.documents4j:documents4j-local:1.0.3'
        implementation 'com.documents4j:documents4j-transformer-msoffice-word:1.0.3' //word
        implementation 'com.documents4j:documents4j-transformer-msoffice-excel:1.0.3' //excel

实现方式:

  public void exportFilePdf(
      Map<String, Object> data, String name, String fileName, HttpServletResponse response)
      throws TemplateException, IOException {
    Configuration configuration = new Configuration(Configuration.getVersion());
    configuration.setClassForTemplateLoading(this.getClass(), "/templates");
    Template template = configuration.getTemplate(name);
    String content = FreeMarkerTemplateUtils.processTemplateIntoString(template, data);

    InputStream inputStream = IOUtils.toInputStream(content);
    int index;
    byte[] bytes = new byte[1024];
    FileOutputStream downloadFile = new FileOutputStream("D:\\data\\a.docx");
    while ((index = inputStream.read(bytes)) != -1) {
      downloadFile.write(bytes, 0, index);
      downloadFile.flush();
    }
    downloadFile.close();
    inputStream.close();

    File inputWord = new File("D:\\data\\a.docx");
//    File outputFile = new File("D:\\data\\a.pdf");
    try {
      InputStream docxInputStream = new FileInputStream(inputWord);
//      OutputStream outputStream = new FileOutputStream(outputFile);
      IConverter converter = LocalConverter.builder().build();
      ServletOutputStream outputStream = response.getOutputStream();
      converter.convert(docxInputStream).as(DocumentType.DOCX).to(outputStream).as(DocumentType.PDF).execute();
      docxInputStream.close();
      outputStream.close();
      inputWord.delete();
      System.out.println("pdf转换成功");
    } catch (Exception e) {
      e.printStackTrace();
    }
  }




  public void exportFileExcel(
          Map<String, Object> data, String name, String fileName, HttpServletResponse response)
          throws TemplateException, IOException {
    Configuration configuration = new Configuration(Configuration.getVersion());
    configuration.setClassForTemplateLoading(this.getClass(), "/templates");
    Template template = configuration.getTemplate(name);
    String content = FreeMarkerTemplateUtils.processTemplateIntoString(template, data);
    InputStream inputStream = IOUtils.toInputStream(content);
    int index;
    byte[] bytes = new byte[1024];
    FileOutputStream downloadFile = new FileOutputStream("D:\\data\\a.docx");
    while ((index = inputStream.read(bytes)) != -1) {
      downloadFile.write(bytes, 0, index);
      downloadFile.flush();
    }
    downloadFile.close();
    inputStream.close();

    File inputWord = new File("D:\\data\\1.xlsx");
//    File outputFile = new File("D:\\data\\a.pdf");
    try {
      InputStream docxInputStream = new FileInputStream(inputWord);
//      OutputStream outputStream = new FileOutputStream(outputFile);
      IConverter converter = LocalConverter.builder().build();
      ServletOutputStream outputStream = response.getOutputStream();
      converter.convert(docxInputStream).as(DocumentType.XLSX).to(outputStream).as(DocumentType.PDF).execute();
      docxInputStream.close();
      outputStream.close();
      inputWord.delete();
      System.out.println("pdf转换成功");
    } catch (Exception e) {
      e.printStackTrace();
    }
  }

SpringBoot实现freemarker填充ftl格式,转Word和PDF 详情可以看我之前的文章:

SpringBoot实现freemarker填充ftl格式,转Word和PDF
原文链接:
https://blog.youkuaiyun.com/The____wind/article/details/134039935

在处理文档换并填充数据的过程中,使用Freemarker模板引擎是关键一步,它可以有效地处理HTML模板中的动态数据部分。为了帮助你深入理解并实践这一过程,推荐你参考这份资源:《WordHTML模板再生成PDF的示例代码详解》。这本教程将带你一步步了解如何操作,包括详细图示和代码实例。 参考资源链接:[WordHTML模板再生成PDF的示例代码详解](https://wenku.csdn.net/doc/83hwijvt8x?spm=1055.2569.3001.10343) 首先,你需要将Word文档换为HTML模板。这通常需要借助专门的换工具或编写定制的脚本,以保持文档格式和布局不变。接着,使用Freemarker填充HTML模板中的动态数据。你可以通过在模板文件中定义变量,并在Java代码中使用Freemarker的API来指定这些变量的具体值。 然后,你需要将填充后的HTML模板换为PDF文件。这个过程可以使用iText等Java库来完成,它能够处理HTML内容并将其渲染到PDF页面上。在此步骤中,确保你的代码能够处理字体、布局以及特殊格式的兼容性问题,特别是在换包含复杂表格和图片的元素时。 最后,要区分本地模板和远程模板的处理方式。本地模板是指直接在本地文件系统中换和处理Word文档,而远程模板则需要通过网络从远程服务器获取模板文件。在不同的使用场景下,都要确保生成PDF文件中不会出现标题丢失或其他格式问题。 在你完成整个换和填充流程后,建议阅读项目中的README.md文档,它包含了项目的基本介绍、安装指南、运行环境要求和操作步骤。项目目录下的示例文件other/也可以帮助你快速理解整个流程。 通过本教程的学习和实践,你将能够有效地将Word文档换为HTML模板,再通过Java和Freemarker处理动态数据填充,并最终生成PDF文件。如果你希望进一步提高在文档处理和模板应用方面的技能,建议继续深入学习相关的高级技术和最佳实践。 参考资源链接:[WordHTML模板再生成PDF的示例代码详解](https://wenku.csdn.net/doc/83hwijvt8x?spm=1055.2569.3001.10343)
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值