java++ftl合并单元格_freemarker实现单元格动态合并-行合并

项目需求:项目中有个需求,需要将一些数据库中的数据根据需求导出,生成一个word,研究了一些技术,其中包括POI、freemaker,对比了一下实现过程及技术难度没最终使用了freemaker;

原始文件

53253e33e4dde8dcd06364067d325c18.png

效果:

7cce7a9cc3e872ef9930b519671b0b16.png

实现过程大概分为三步,第一步:根据word文件做模板,修改模板,导出word。这里主要记录一下过程中遇到的一些情况。

一、制作模板

打开word文件,为要添加数据的地方打标签,,使用${key}的方式,key将来就是数据Map中的key,需要保持一致。然后另存为XML,因为word本质上就是个XML

bb18059f8355fad6ea740e3108b715ea.png

49abd38affeced2dba150316f77650bd.png

二、处理XML文件

使用FirstObject XML Edito或者其他工具打开,我是用的是NotePad++,打开需要格式话一下,要不然没法看,打开主要是处理以下的情况:

6427b0fbbc867371a40f89b5f2e1289f.png

这个是分开的,需要将中间的部分删除,处理后如下:

cde2192ef3f05dd85747656b84f45919.png

全部处理好之后,文件另存为ftl文件,这个就是我们制作完成的模板。

三、数据处理、打标签

这里主要说的是需要循环并且还需要合并单元格的情况。如果没有这些情况,直接打标签,封装数据就可以了。

第一个:list

主要是将数据封装到list中,list中是若干个Map,如图:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值