1. 描述
数据库中保存的是如下形式的编码:%u5357%u4EAC-%u57CE%u5317 希望最后展示出来的是对应的中文“南京-城北”
FineReport 提供了自定义函数机制,可以由用户根据业务需要自己来定义一些函数,但这些函数必须满足 FineReport 函数定义规则。
2. 函数原理
在 FineReport 中,每一个函数都被定义成一个类,这个类必须要实现 Function 这个接口,在运算的时候首先通过函数名反射取得这个类,然后调用它的 run(Object[] agrs)方法。下面Ubm这个函数可以实现:
3. 实现步骤
3.1 编写自定义函数代码详见:
https://code.fanruan.com/demo/example/src/branch/persist/10.0/src/main/java/com/fr/function/Ubm.java
3.2 编译自定义函数
将编译后的 Ubm.class 放到 FineReport 的安装目录 WEB-INF 下面的 classes 目录下,因为 Ubm.java 属于包com.fr.function,所以Ubm.class需要放到%FR_HOME%\webapps\webroot\WEB-INF\classes\com\fr\function目录下。
3.3 注册自定义函数
生成该函数的类后需要在设计器中进行注册,才可以使用该函数。打开服务器|函数管理器选择刚刚定义好了 Ubm 类,如下图:
3.4 使用自定义函数
注册好自定义函数后,制作报表时便可直接使用了,使用方法与内置的函数是相同的。输入公式=Ubm("%u5357%u4EAC-%u57CE%u5317"),预览效果如下: