• 登录

反馈已提交

网络繁忙

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

  • 文档创建者: lu123
  • 历史版本: 14
  • 最近更新: Wendy123456 于 2022-07-21
  • 1. 概述

    1.1 问题描述

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

    如何在自定义函数中获取公式所在单元格呢,如在 A1 单元格中使用了自定义的函数,在执行时获取到 A1。

    1.2 解决方案

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

    2. 示例

    我们来重写 sum 公式,在返回最终汇总值时,同时返回公式所在单元格,如下图:

    1658369730582349.png

    2.1 准备编译环境

    编译程序前,需先创建一个Java工程环境,并且需要一个Java 编辑器,如 Eclipse 或 idea 。

    在编辑器下打开工程,选择「Properties>Java Build Path>Libraries」,导入 FineReport 工程 JAR 包,详细操作可参考: 编译Java程序

    2.2 编写自定义函数

    在编译器中编写 CellSum 自定义函数,Java 代码如下:

    https://code.fanruan.com/demo/example/src/branch/persist/10.0/src/main/java/com/fr/function/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

    111.png

    2.4 注册自定义函数

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

    2222.png

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

    2.png

    2.5 模板制作

    制作模板。新建普通报表,在单元格 A1 中输入 1,A2 中输入 2,A3 中写入公式CellSum(A1,A2)(函数名大小写不区分)。如下图所示:

    333.png

    2.6 效果查看

    保存模板,点击「分页预览」就可以实现获取公式所在的单元格及两个单元格的汇总值了。

    222

    附件列表


    主题: 二次开发
    上一篇:图片在下文字在上
    下一篇:自定义函数把阳历转换成阴历
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(繁體) English 日本語
    中文(简体)

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问 或 前往服务平台 获取技术支持

    两个鬼故事什么是民生问题联通号段哪里的拼音什么是最大公约数身份证补办程姓少女起名字萌娘守护者松本莉绪卢姓女人起名分数高的微微一笑很倾城网盘qq男生伤感头像大全移动家庭套餐明星 起名给村庄起名字美容养身起名免费的起名网站的郑氏郑姓介绍起名女孩从百草园到三味书屋原文1免费起名起名字姓宁猪年给孩子起名大全花羡人间四丁目父爱作文玩游戏起什么名字好孩子起名字宝典www.txtbook.com棉花糖歌词伊起名字网起名免费测试寓意很好的成语可起名字少年生前被连续抽血16次?多部门介入两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”淀粉肠小王子日销售额涨超10倍高中生被打伤下体休学 邯郸通报单亲妈妈陷入热恋 14岁儿子报警何赛飞追着代拍打雅江山火三名扑火人员牺牲系谣言张家界的山上“长”满了韩国人?男孩8年未见母亲被告知被遗忘中国拥有亿元资产的家庭达13.3万户19岁小伙救下5人后溺亡 多方发声315晚会后胖东来又人满为患了张立群任西安交通大学校长“重生之我在北大当嫡校长”男子被猫抓伤后确诊“猫抓病”测试车高速逃费 小米:已补缴周杰伦一审败诉网易网友洛杉矶偶遇贾玲今日春分倪萍分享减重40斤方法七年后宇文玥被薅头发捞上岸许家印被限制高消费萧美琴窜访捷克 外交部回应联合利华开始重组专访95后高颜值猪保姆胖东来员工每周单休无小长假男子被流浪猫绊倒 投喂者赔24万小米汽车超级工厂正式揭幕黑马情侣提车了西双版纳热带植物园回应蜉蝣大爆发当地回应沈阳致3死车祸车主疑毒驾恒大被罚41.75亿到底怎么缴妈妈回应孩子在校撞护栏坠楼外国人感慨凌晨的中国很安全杨倩无缘巴黎奥运校方回应护栏损坏小学生课间坠楼房客欠租失踪 房东直发愁专家建议不必谈骨泥色变王树国卸任西安交大校长 师生送别手机成瘾是影响睡眠质量重要因素国产伟哥去年销售近13亿阿根廷将发行1万与2万面值的纸币兔狲“狲大娘”因病死亡遭遇山火的松茸之乡“开封王婆”爆火:促成四五十对奥巴马现身唐宁街 黑色着装引猜测考生莫言也上北大硕士复试名单了德国打算提及普京时仅用姓名天水麻辣烫把捣辣椒大爷累坏了

    两个鬼故事 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化