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

版权声明:https://blog.csdn.net/xianzhuo_sky https://blog.csdn.net/xianzhuo_sky/article/details/82662355

前些时间在做一个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了
计数方法使用

猜你喜欢

转载自blog.csdn.net/xianzhuo_sky/article/details/82662355