finereport自定义函数怎么访问单元格

 我来答
帆软
2016-12-08 · 上BI选帆软,专注BI十三年!
帆软
帆软软件是世界领先的商业智能和数据分析平台提供商,沉淀数据分析领域十余年,致力于为全球企业提供一站式数据分析解决方案;同时也是行业优质交流平台的组织者。
向TA提问
展开全部

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

来充血sum公式,在返回最终汇总值时,同时返回公式所在单元格,如下图:

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;  
    }  
}

2、编译自定义函数

编译cellsum.java类生成cellsum.class文件,并进行拷贝。

3、注册自定义函数

启动设计器,点击服务器>函数管理器,新增函数取名为cellsum,选择cellsum.class类,如下图:

此时自定义函数便定义好了,可以在设计器中使用该函数。

4、使用自定义函数

在单元格A1中输入1,A2中输入2,A3中写入公式=cellsum(A1,A2),保存模板预览便可以获取公式所在的单元格了。

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式