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

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前些时间在做一个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 = jxlsHelper.createTransformer(is, os);
JexlExpressionEvaluator evaluator = (JexlExpressionEvaluator)transformer.getTransformationConfig().getExpressionEvaluator();
Map<String, Object> funcs = new HashMap<String, Object>();
funcs.put("utils", new JxlsUtils()); //添加自定义功能
evaluator.getJexlEngine().setFunctions(funcs);

我们可以自己写一个each计数工具方法
首先我们需要在工具类中声明一个全局变量(非static),用户存放计数数据

private Map<String,Integer> countMap = new HashMap<>(); //用于jxls的foreach循环计数

然后在工具类中写计数方法,下面是我写的计数方法

public Integer count(String var){
  if (var == null) return null;
  if(countMap.containsKey(var)){
    Integer t = countMap.get(var);
    t += 1;
    countMap.replace(var,t);
    return t;
  }else{
    countMap.put(var,1);
  }
  return 1;
}

参数var传我们在模板上写的each命令中var的属性名,在一个模板中可以多次使用each命令并分别计数,但是每个each命令中的var属性名不要相同

现在我们就可以在遍历时填写当前索引了,比如我们现在有这样一条遍历命令
jx:each(items=“apples” var=“apple” lastCell=“Q15”)
我们在需要填写索引的单元格上填写${utils:count(“apple”)}就OK了
计数方法使用

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值