自定义函数中获取公式所在单元格

编辑
文档创建者:印然 (67260 )     浏览次数:7381次     编辑次数:7次     最近更新:jiangsr 于 2019-03-13     

目录:

1. 描述编辑

执行自定义函数时获取到公式所在的单元格,在日志信息中输出使用函数的单元格从而监控报表是否正常执行或者根据公式所在单元格位置的不同采取不同的计算方法。
如何在自定义函数中获取公式所在单元格呢,如在A1单元格中使用了自定义的函数,在执行时获取到A1。

2. 解决方案编辑

在自定义函数的run方法中,可以通过this.getCalculator().getCurrentColumnRow()来获取公式所在单元格。

3. 示例编辑

我们来重写sum公式,在返回最终汇总值时,同时返回公式所在单元格,如下图:
222
3.1 编写自定义函数
package com.fr.function; import com.fr.base.Utils; import com.fr.script.AbstractFunction; public class CellSum extends AbstractFunction { 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; } }
3.2 编译自定义函数
编译CellSum.java类生成CellSum.class文件,并拷贝至%FR_HOME%\webapps\webroot\WEB-INF\classes\com\fr\functio下。
3.3 注册自定义函数
启动设计器,点击服务器>函数管理器,新增函数取名为CellSum,选择CellSum.class类,如下图:
222
此时自定义函数便定义好了,您可以在设计器中使用该函数。
3.4 预览效果

在单元格A1中输入1,A2中输入2,A3中写入公式=CellSum(A1,A2)(函数名大小写不区分),保存模板预览便可以获取公式所在的单元格了。
222




附件列表


主题: 二次开发
如果您认为本文档还有待完善,请编辑

文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201

此页面有帮助吗?只是浏览 [ 去社区提问 ]