博客
关于我
帆软报表自定义函数-取json数据
阅读量:613 次
发布时间: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/

你可能感兴趣的文章
Node.js初体验
查看>>
Node.js升级工具n
查看>>
Node.js卸载超详细步骤(附图文讲解)
查看>>
Node.js卸载超详细步骤(附图文讲解)
查看>>
Node.js基于Express框架搭建一个简单的注册登录Web功能
查看>>
node.js学习之npm 入门 —8.《怎样创建,发布,升级你的npm,node模块》
查看>>
Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
查看>>
Node.js安装及环境配置之Windows篇
查看>>
Node.js安装和入门 - 2行代码让你能够启动一个Server
查看>>
node.js安装方法
查看>>
Node.js官网无法正常访问时安装NodeJS的方法
查看>>
node.js模块、包
查看>>
node.js的express框架用法(一)
查看>>
Node.js的交互式解释器(REPL)
查看>>
Node.js的循环与异步问题
查看>>
Node.js高级编程:用Javascript构建可伸缩应用(1)1.1 介绍和安装-安装Node
查看>>
nodejs + socket.io 同时使用http 和 https
查看>>
NodeJS @kubernetes/client-node连接到kubernetes集群的方法
查看>>
NodeJS API简介
查看>>
Nodejs express 获取url参数,post参数的三种方式
查看>>