博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
报表开发之自定义函数
阅读量:6514 次
发布时间:2019-06-24

本文共 2886 字,大约阅读时间需要 9 分钟。

对于报表开发,很多情况下,自带的函数就能满足大部分用户的报表制作需求,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函数所使用代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
packagecom.fr.report.script;
importjava.lang.reflect.Array;
importcom.fr.report.script.core.FArray;
importcom.fr.report.script.core.FunctionHelper;
public 
class 
SUM extendsAbstractFunction {
         
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]);
                   
}
                   
returnFunctionHelper.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 
{
                                     
returnDouble.parseDouble(obj.toString());
                            
catch 
(NumberFormatException exp) {
                                     
return 
0
;
                            
}
                   
}
                   
return 
0
;
         
}
}

实现步骤

编写自定义函数

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

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

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

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
package 
com.fr.function;
  
importcom.fr.script.AbstractFunction;
  
public 
class 
StringCatextends 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公式可以正常使用啦。

本文转自 雄霸天下啦 51CTO博客,原文链接:http://blog.51cto.com/10549520/1828359,如需转载请自行联系原作者
你可能感兴趣的文章
DNS解析偶尔延迟
查看>>
iOS打电话,发短信,发邮件,打开网址
查看>>
06-验证码-基本功能实现
查看>>
Java数据结构与算法(六) 希尔排序
查看>>
canvas学习笔记
查看>>
elasticsearch安装步骤
查看>>
PHP获取Cookie模拟登录CURL(转)
查看>>
PHP-权限控制类(转)
查看>>
CSS3秘笈第三版涵盖HTML5学习笔记9~12章
查看>>
bzoj1044木棍分割
查看>>
leetcode-136-Single Number
查看>>
http服务器小项目
查看>>
一些数学上的名词及操作
查看>>
Flume 读取实时更新的日志文件
查看>>
HDU 2049
查看>>
《Spring1之第十次站立会议》
查看>>
Unity Shader 噪声消融特效 - 剑灵死亡特效
查看>>
Eclipse 自动生成 Ant的Build.xml 配置文件
查看>>
添加一条信息到列表,如果重复就替换,
查看>>
C#基础第五天
查看>>