freemarker模板进行word导出表格,相同单元格合并,遍历数据批量导出

最近研究word文件导出,导出表格并且相同单元格合并,在数据量庞大的情况下性能较好

首先有两种思想,一种是poi导出,一种就是freemarker模板导出。首先说说poi的缺点吧,poi等于是用Java代码制作word模板,而且最不方便的就是poi对word很不友好,excel的各种方法应有尽有,word的少的可怜;而且代码繁琐,数量庞大,如果有其他同事需要编写相同的功能,需要把所有poi方法全部学习一遍,实在是太过麻烦,最终选择了使用freemarker

步骤1:创建模板

模板在创建时固定数据不变,需要循环遍历的数据写上你数据对应Map的key,数据封装应该是由Map<String,List<Map<String,Object>>>对应的数据就是list的别名 "." map的key。

步骤2:另存为xml格式文件 

另存为保存的文件格式为xml文档,因为word的本身就是xml,注意不要导出2003版本,个人使用时导出2003版本数据可以正常导出,但是无法自动合并单元格 。(大家可以试一试,不知道是不是我的问题)

 步骤3:编辑xml文件

 另存为的xml文件可以用两种方式打开:

  1. 个人偏向于idea打开,因为格式化后代码可读性很高,关键字也有标注清楚
  2. 其次就是node++打开,用此方法打开时注意第三方插件格式化代码

 在“可用”中搜索xml tools,这里因为我已经安装了

 具体编辑方法如上图所示,有几列需要自动合并单元格,就添加几个变量,我是有两列,所有有两个变量,注意list和变量要写在你导出数据的单元格那一行标签上面,然后在这一行的结尾用list收尾

这一行收尾一般在tbl标签上方

 步骤4:改变文件后缀名

改变文件后缀名为ftl

步骤5:添加依赖

maven的使用就不多言了,上依赖

<dependency>
    <groupId>org.freemarker</groupId>
    <artifactId>freemarker</artifactId>
    <version>2.3.28</version>
</dependency>

这里注意版本不能太低,不然很多底层代码会缺斤少两,出现很多问题

步骤6:Java工具类

    /**
    *
    * @param map 导出的数据
    * @param saveFilePath 储存的文件地址
    * @param templatePath ftl模板路径
    * @param ftlName ftl模板文件名
    * @throws IOException 流异常,找不到文件
    * @throws TemplateException 找不到ftl模板异常
    */
    public static void setExportFree(Map<String, Object> map,String saveFilePath,String templatePath,String ftlName) throws IOException, TemplateException {
        Configuration configuration = new Configuration();
        configuration.setDefaultEncoding("UTF-8");
        configuration.setDirectoryForTemplateLoading(new File(templatePath));
        Template t = configuration.getTemplate(ftlName);
        File outFile = new File(saveFilePath);
        FileOutputStream fos = new FileOutputStream(outFile);
        OutputStreamWriter oWriter = new OutputStreamWriter(fos, StandardCharsets.UTF_8);
        Writer out = new BufferedWriter(oWriter);
        t.process(map, out);
        out.close();
        oWriter.close();
        fos.close();
    }
String templatePath = "D:/xxx/ftl";
String ftlName = "xxx.ftl";
Map<String, Object> map1 = new HashMap<>();
map1.put("infos", list);
String saveFilePath = "D:/xxx/my1.doc";
ExportFree.setExportFree(map1,saveFilePath,templatePath,ftlName);

步骤7:导出完成

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Freemarker 是一种模板引擎,可用于动态生成文档,包括导出 Word 文档。在 Word 中拆分表格单元是一个常见的需求,在使用 Freemarker 导出 Word 表格时,也可以通过一些技巧来实现。 首先,我们需要将表格数据传递给 Freemarker 模板。可以通过一个二维数组或者一个包含多个 Map 的 List 来表示表格数据。每个 Map 表示表格的一行数据,其中的 key 表示列的标题,value 表示该单元的内容。 然后,在 Freemarker 模板中,可以使用表格标签来生成表格。使用嵌套的 #list 指令来遍数据,使用嵌套的 #items 指令来遍数据。可以通过设定参数来控制表格的样式,例如边框、背景颜色等。 接下来,需要判断是否需要拆分单元。可以在模板中使用 #if 指令来判断某个条件是否满足,例如某个单元的内容是否符合拆分的条件。如果需要拆分,则可以使用 colspan 和 rowspan 参数来控制单元合并和拆分。 需要注意的是,在拆分单元时,应该确保表格的结构仍然正确,不会造成表格乱码或无法显示的问题。可以通过在表格标签中增加条件判断、控制行和列的合并等方式来调整表格结构。 最后,通过 Freemarker模板引擎将数据应用于模板,并将生成的 Word 文档导出保存即可。 总结起来,使用 Freemarker 导出 Word 表格并拆分单元,需要将表格数据传递给 Freemarker 模板,通过判断条件来决定是否拆分单元,并注意保持表格结构的正确性。这样就可以生成带有拆分单元Word 文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值