星空网 > 软件开发 > Java

报表开发之自定义函数

对于报表开发,很多情况下,自带的函数就能满足大部分用户的报表制作需求,FineReport也不例外。但是在一些特殊领域,可能需要一些特殊的函数,在这种情况下,FineReport提供了自定义函数机制,可以由用户根据业务需要自己来定义一些函数,但这些函数必须满足函数定义规则。

先来了解一下FineReport的函数定义规则:Functionname(Para,Para,...),其中Functionname为函数名,Para为参数。

每一个函数都被定义成一个类,这个类必须要实现Function这个接口,在运算的时候首先通过函数名反射取得这个类,然后调用它的run(Object[] agrs)方法。下面以SUM这个函数为例。

SUM函数原理

由程序可以看到,SUM类用来运算SUM函数,他继承了AbstractFunction类,而AbstractFunction实现了Function这个接口。

当函数运算的时候,先根据函数名取得运算该函数的类,如SUM(2,4,true)这个函数先根据函数名取得SUM这个类,然后调用SUM类的run(Object[] args)方法,args中存放的是SUM函数的参数,运算的时候可以从args中取得参数进行运算。如执行结果为SUM(2,4,true)=2+4+1=7。

SUM函数所使用代码:

package com.fr.report.script;import java.lang.reflect.Array;import com.fr.report.script.core.FArray;import com.fr.report.script.core.FunctionHelper;public class SUM extends AbstractFunction {	public Object run(Object[] args) {		double result = 0;		for (int i = 0; i < args.length; i++) {			if (args[i] == null) {				continue;			}			result += parseObject(args[i]);		}		return FunctionHelper.parsePrimitiveDouble(result);	}	private double parseObject(Object obj) {		if (obj instanceof Number) {			return ((Number) obj).doubleValue();		} else if (obj instanceof Boolean) {			return ((Boolean) obj).booleanValue() ? 1 : 0;		} else if (obj instanceof FArray) {			FArray array = (FArray) obj;			double sum = 0;			for (int i = 0; i < array.length(); i++) {				sum += parseObject(array.elementAt(i));			}			return sum;		} else if (obj != null) {			try {				return Double.parseDouble(obj.toString());			} catch (NumberFormatException exp) {				return 0;			}		}		return 0;	}}

实现步骤

编写自定义函数

下面以一个简单的自定义函数例子来说明使用自定义函数。我们定义一个函数StringCat,他的作用是把所有的参数以字符串的形式连接起来。

StringCat函数使用规则为StringCat(Para,Para,Para…….);

其中Para为该函数的参数,个数不限。

由概述可知AbstractFunction实现了Function这个接口,因此StringCat可以直接继承AbstractFunction类,完整代码如下:

package com.fr.function;import com.fr.script.AbstractFunction;public class StringCat extends AbstractFunction {	public Object run(Object[] args) {		String result = "";		Object para;		for (int i = 0; i < args.length; i++) {			para = args[i];			result += para.toString();		}		return result;	}}

这里要注意,使用函数StringCat(Para,Para,Para…..)时,根据函数名取得运算该函数的类StringCat,并将参数传入类中的args对象数组中,执行该类的run函数。




而在run函数中即实现了将传入的参数以字符串的形式连接起来。并返回最终形成的字符串。

编译自定义函数

将编译后的StringCat.class放到FineReport的安装目录WEB-INF下面的classes目录下,因为StringCat.java属于包com.fr.function,所以StringCat.class需要放到classes\com\fr\function目录下。

注册自定义函数

生成该函数的类后需要在设计器中进行注册,才可以使用该函数。打开服务器|函数管理器,选择刚刚定义好了StringCat类,如下图

报表开发之自定义函数

函数名称可以自定义,如这边定义为StringCat;

同时可以添加该函数的使用说明,如上图所示的描述

使用自定义函数

注册好自定义函数后,制作报表时便可直接使用了,使用方法与内置的函数是相同的。

新建报表,定义两个报表参数para1、para2,类型分别为字符串型与整形,默认值分别为空字符串与0

报表开发之自定义函数

在空白报表的任意单元格里写入公式:=StringCat($para1,$para2)(注意:写入公式的时候在参数名前加$,表明这是使用的参数)

点击分页预览在参数控件中,写入参数值如para1为:FineReport,para2为:123。

 点击查询可以看到结果

报表开发之自定义函数

说明StringCat公式可以正常使用啦。




原标题:报表开发之自定义函数

关键词:函数

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

Shopee运营:中小卖家运营经理的一天是什么样的?:https://www.ikjzd.com/articles/111717
亚马逊销量无法持续上涨,可能是这些原因!:https://www.ikjzd.com/articles/111718
注意!别让这些“未知的恐惧”毁了你的外贸之路!:https://www.ikjzd.com/articles/111719
报关高值低报,外贸人你是认真的吗?:https://www.ikjzd.com/articles/111720
亚马逊美国站耳塞式耳机行业数据报告!:https://www.ikjzd.com/articles/111721
超1.5亿次点击!Shopee小游戏引爆东南亚购物风潮!:https://www.ikjzd.com/articles/111723
亚马逊德国包装法注册流程:https://www.kjdsnews.com/a/1842106.html
亚马逊德国包装法注册流程:https://www.xlkjsw.com/news/91225.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流