自定义工具方法实现jxls2中each循环计数

博客介绍了在jxls2中,由于each命令没有varStatus属性来记录遍历状态,作者提出了一种解决方案。通过在工具类中创建自定义方法,实现each循环过程中的计数功能,从而在导出Excel时能显示当前索引。方法包括在工具类中声明全局变量并编写计数方法,然后在模板中调用此方法填充单元格。
摘要由CSDN通过智能技术生成

前些时间在做一个excel导出功能时,看了下项目中使用了poi和jxl这两种excel导出库,觉得这两种导出库使用起来生硬繁琐,于是便在网上找到了这个使用模板能够灵活导出excel的jxls2。


jxls2的基本使用方法就不具体介绍了,jxls2和jxls的一代版本有很大差异,请大家注意区分。

在使用jxls2时,我们经常会用到each命令来循环导出数据。each命令的基本写法为:

jx:each(items=“apples” var=“apple” lastCell=“Q15”)

each 可以有如下一些属性:
items 上下文中集合的变量名;
var 在遍历集合的时候每一条记录的变量名;
area 该XLS Command的解析区域;
direction 数据在excel中填充的方向,默认(DOWN)向下;
select 其值为一个表达式,用来过滤数据。

jxls2的each命令并没有varStatus这样一个属性来存放当前遍历状态

但是我们经常会在each遍历过程中需要一个计数器来记录当前已经遍历的个数,或者需要将索引打印在单元格上

对于这个问题我想出了一个解决方法

jxls2是可以在工具类中写自定义工具方法的

如果你需要自定jexl来处理数据,你可以从Transformer对象获取JexlEngine引用,并对其配置。

下面的例子实现了将一个自定义jexl函数注册到utils命名空间下:

JxlsHelper jxlsHelper = JxlsHelper.getInstance();
Transformer transformer 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值