博客
关于我
帆软报表自定义函数-取json数据
阅读量:612 次
发布时间:2019-03-12

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

帆软报表支持,写 Java 代码自定义函数,完成各种逻辑的取数。

 

最近遇到一个需求,单元格里的数据是 json 格式,希望通过自定义一个函数完成取数。

取数公式如:

JSONVAL('{"k1":"v1", "k2":["v21", "v22"], "k3":{"k31":"v31"}}', 'k1') -> v1JSONVAL('{"k1":"v1", "k2":["v21", "v22"], "k3":{"k31":"v31"}}', 'k2', 0) -> v21JSONVAL('{"k1":"v1", "k2":["v21", "v22"], "k3":{"k31":"v31"}}', 'k3', 'k31') -> v31JSONVAL('[1, "2", {"k1":"v1"}]', 2, 'k1') -> v1

 

Web 项目使用了 Gson 解析和生成 json 格式的数据,这里基于 Gson 实现。

代码如下: 

package com.fr.function;import com.fr.script.AbstractFunction;import com.fr.stable.Primitive;import com.google.gson.JsonArray;import com.google.gson.JsonElement;import com.google.gson.JsonObject;import com.google.gson.JsonParser;/** * 帆软json取数,支持多层级 * 如: * JSONVAL('{"k1":"v1", "k2":["v21", "v22"], "k3":{"k31":"v31"}}', 'k1') -> v1 * JSONVAL('{"k1":"v1", "k2":["v21", "v22"], "k3":{"k31":"v31"}}', 'k2', 0) -> v21 * JSONVAL('{"k1":"v1", "k2":["v21", "v22"], "k3":{"k31":"v31"}}', 'k3', 'k31') -> v31 * JSONVAL('[1, "2", {"k1":"v1"}]', 2, 'k1') -> v1 * @author ConstXiong */public class JSONVAL extends AbstractFunction{	private static final long serialVersionUID = 1L;	@Override	public Object run(Object[] arg) {		int paramLength = arg.length;		if (paramLength < 2 || arg[0] == null || arg[1] == null) {			return Primitive.ERROR_NAME;		}		try {			JsonParser parser = new JsonParser();			JsonElement jsonEle = parser.parse(arg[0].toString());			for (int i = 1; i < paramLength; i++) {				if (jsonEle.isJsonObject() && arg[i] instanceof String) {					jsonEle = ((JsonObject)jsonEle).get(arg[i].toString());				} else if (jsonEle.isJsonArray() && arg[i] instanceof Integer) {					jsonEle = ((JsonArray)jsonEle).get((Integer)arg[i]);				} else {					return Primitive.ERROR_VALUE;				}			}			//此时 jsonEle 仍可能是 JsonObject 或 JsonArray,暂不处理			return jsonEle.getAsString();		} catch (Exception e) {			return Primitive.ERROR_VALUE;		}	}	}

 

使用如图:

 

 


【Java面试题与答案】整理推荐

 

转载地址:http://roaxz.baihongyu.com/

你可能感兴趣的文章
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>