二次开发、自定义函数中获取公式所在单元格
1. 问题描述
执行自定义函数时获取到公式所在的单元格,在日志信息中输出使用函数的单元格从而监控报表是否正常执行或者根据公式所在单元格位置的不同采取不同的计算方法。
如何在自定义函数中获取公式所在单元格呢,如在A1单元格中使用了自定义的函数,在执行时获取到A1。
2. 解决方案
在自定义函数的run方法中,可以通过this.getCalculator().getCurrentColumnRow()来获取公式所在单元格。
3. 示例
我们来重写sum公式,在返回最终汇总值时,同时返回公式所在单元格,如下图:
3.1 编写自定义函数
3.2 编译自定义函数
编译CellSum.java类生成CellSum.class文件,并拷贝至%FR_HOME%/WebReport/WEB-INF/classes/com/fr/function下。
3.3 注册自定义函数
启动设计器,点击服务器|函数管理器,新增函数取名为CellSum,选择CellSum.class类,如下图:
此时自定义函数便定义好了,您可以在设计器中使用该函数。
3.4 使用自定义函数
在单元格A1中输入1,A2中输入2,A3中写入公式=cellsum(A1,A2)(函数名大小写不区分),保存模板预览便可以获取公式所在的单元格了。
返回顶部