1. 概述
1.1 问题描述
执行自定义函数时获取到公式所在的单元格,在日志信息中输出使用函数的单元格从而监控报表是否正常执行或者根据公式所在单元格位置的不同采取不同的计算方法。
如何在自定义函数中获取公式所在单元格呢,如在 A1 单元格中使用了自定义的函数,在执行时获取到 A1。
1.2 解决方案
在自定义函数的 run 方法中,可以通过this.getCalculator().getCurrentColumnRow()来获取公式所在单元格。
2. 示例
我们来重写 sum 公式,在返回最终汇总值时,同时返回公式所在单元格,如下图:
2.1 准备编译环境
编译程序前,需先创建一个Java工程环境,并且需要一个Java 编辑器,如 Eclipse 或 idea 。
在编辑器下打开工程,选择「Properties>Java Build Path>Libraries」,导入 FineReport 工程 JAR 包,详细操作可参考:编译Java程序
2.2 编写自定义函数
在编译器中编写 CellSum 自定义函数,Java 代码如下:
package com.fr.function;
import com.fr.base.Utils;
import com.fr.script.AbstractFunction;
public class CellSum extends AbstractFunction {
@Override
public Object run(Object[] args) {
String sum = Utils.objectToNumber(new SUM().run(args), false)
.toString(); // 直接调用FR内部的SUM方法
String result = "所在单元格为:" + this.getCalculator().getCurrentColumnRow()
+ ";总和为:" + sum; // 获取当前单元格拼出最终结果
return result;
}
}
2.3 编译自定义函数
编译 CellSum.java 类生成 CellSum.class 文件,并拷贝至%FR_HOME%\webapps\webroot\WEB-INF\classes\com\fr\function下。
点击可下载:CellSum.zip
2.4 注册自定义函数
启动设计器,点击「服务器>函数管理器」,新增函数并取名为 CellSum,选择 CellSum.class 类,如下图:
此时自定义函数便定义好了,您可以在设计器中使用该函数。
2.5 模板制作
制作模板。新建普通报表,在单元格 A1 中输入 1,A2 中输入 2,A3 中写入公式CellSum(A1,A2)(函数名大小写不区分)。如下图所示:
2.6 效果查看
保存模板,点击「分页预览」就可以实现获取公式所在的单元格及两个单元格的汇总值了。