使用freemarker生成复杂的excel表格

1 篇文章 0 订阅
1 篇文章 0 订阅

首先这个idea和做法是来自于这位大哥的 http://blog.csdn.net/u010722643/article/details/41732607 我在公司的开发上运用了这一套,然后+上了自己的一些内容,所以希望大家如果要学习或了解原理的话,还是看看这位大哥的原文,蛮不错的一篇文章,以下内容主要从实操为主。

要实现freemarker的模板导出,是需要把excel文件转化成模板文件,一种freemarker可以识别的格式.ftl:这里写图片描述
1、选一个比较纯净的excel文件,最好是把对应的excel条数给删掉,然后保存excel成microsoft自带的xml格式

2、然后相对应的,把.xml的后缀改为.ftl格式的,直接修改文件名就可以了!
3、最后就是要修改对应的内容,把无关的标签删掉以及增加动态的freemarker标签,实现动态生成excel表格的功能:
对于一个.ftl文件来说,需要的是设置对应的动态生成的标签。这里写图片描述

像这里就是酱紫,必须动态的设置对应的自增,这里用到了JSTL的语法,对应的对象用$符号包裹,意思是循环并获得对象。这里写图片描述

4、这边用了list来递归循环数据。
我这里用了两个workSheet来展示数据,也是这个freemarker给予我们优势的地方,把两个表格二合一到一个excel里面,做法其实就是再创建一个workSheet来就行了。
我后续会加上对应的下载模板的一个链接,只要格式对了,就能简单的导出excel了!
5、最后就是上代码了!
这里写图片描述

要注意的就是 这个out是Spring mvc里面的httpResponse.getWriter()方法获得的!

总结:诚然,用这种方式生成的excel是方便,但是总的来说,兼容性不太好,实际上这个生成的是一套xml文件,在wps和microsoft excel下打开是正常的,但是每次都会提示格式不正确(microsoft excel),但是又可以打开,而在移动端的表现也是差强人意,android可以打开,然而在IOS的情况下就打开不了,或者打开就被识别成了xml格式。
像这种情况,我还是觉得用POI去实现导出会是更好的选择,导出生成真正的excel才是最佳的选择。

SpringBoot_Freemarker生成Word_多个表格+两层嵌套循环; 步骤说明: 1.用Microsoft Office Word打开word原件;将文档中需要动态生成的内容,替换为属性名 ${name} 2.另存为,选择保存类型Word 2003 XML 文档(*.xml) 3.用Firstobject free XML editor打开文件,选择Tools下的Indent【或者按快捷键F8】格式化文件内容。左边是文档结构,右边是文档内容; 4. 文档生成后有时需要手动修改,查找第一步中设置的属性名,可能会产生类似${n.....ame}类似的样子,我们将将名字中间的标签删掉,恢复为${name} 5. word模板中有表格,需要循环的位置, 用 标签将第二对 标签(即除表头的w:tr标签后的一对)包围起来 同时表格内的属性例如${name},在这里需要修改为${user.name} (userList是集合在dataMap中的key, user是集合中的每个元素, 类似), 如图: PLUS:若表格之外还有嵌套的循环,也需要用,注意这里的标签不要和某对其他标签交叉,不可以出现这种 6. 标识替换完之后,另存为.ftl后缀文件即可。 代码里是相对有一丢丢复杂的,两层嵌套循环; 总(dataMap) deptName 部门名 list(Table)表的集合 table1(map) table-名字 ${map.table} tableName-中文名 ${map.tableName} columnCount-字段数 ${map.columnCount} recordCount-记录数 ${map.recordCount} listA-List--表格1 map.listA column Model属性——字段名 ${model.column} columnName Model属性——字段中文名 ${model.column} rate Model属性——字段占比 ${model.rate} nullValueCount Model属性——字段空值数 ${model.nullValueCount} listB-List--表格2 map.listB …… listC-List--表格3 map.listC …… table2 table-名字 ${map.table} tableName-中文名 ${map.tableName} columnCount-字段数 ${map.columnCount} recordCount-记录数 ${map.recordCount} listA-List--表格1 map.listA column Model属性——字段名 ${model.column} columnName Model属性——字段中文名 ${model.column} rate Model属性——字段占比 ${model.rate} nullValueCount Model属性——字段空值数 ${model.nullValueCount} listB-List--表格2 map.listB …… listC-List--表格3 map.listC …… table3 ……
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值