java接收json数据_java 如何简单快速处理 json 中的数据

JSONstr.json的runners字段是子文档,子文档有3个字段:horseId、ownerColours、trainer,其中trainer含有下级字段trainerId。需要根据文档序号查询对应子文档的horseId、ownerColours、trainerId字段。部分源数据如下:

[

{

"race": {

"raceId":"1.33.1141109.2",

"meetingId":"1.33.1141109"

},

...

"numberOfRunners": 2,

"runners": [

{

"horseId":"1.00387464",

"trainer": {

"trainerId":"1.00034060"

},

"ownerColours":"Maroon,pink sleeves,dark blue cap."

},

{

"horseId":"1.00373620",

"trainer": {

"trainerId":"1.00010997"

},

"ownerColours":"Black,emerald green cross of lorraine,striped sleeves."

}

]

},

...

]

期望Json结构化后的效果:

0e6cc306fb32c4e4c56d7668b5ee7084.png

Java只提供了解析Json的基础类库,但API接口多而繁琐,如果想进行深入的计算,仍然需要复杂硬编码。大概要写成这样:

...

JSONObject jsonObject = JSONObject.fromObject(s);

JSONArray result = jsonObject.getJSONArray("runners");

for (int i = 0; i < result.size(); i++) {

JSONArray index = result.getJSONObject(i).getJSONArray("index");

...

}

...

Json解析,用集算器SPL会简单很多,它把Json类库做了二次封装,且有丰富强大的集合运算能力,所以很容易应对。比如上面问题,取出第 1 个 runners 字段 (子文档),仅需3行:

70de479b8ac633f2ca851ddb501a32c8.png

Json 解析出来一般都是为了计算,所以 SPL 还能更方便地计算,比如:按 horseId 分组统计每组中 ownerColours 出现的次数;只需在此基础上增加 1 行:=A3.groups(horseId;~.array().count():times)。其实还有很多情况用Java解析Json不太方便,甚至计算入库等需求,但用集算器SPL却很简单,感兴趣可以参考:轻松应对多层JSON数据计算与入库。

集算器还很容易嵌入到Java应用程序中,Java如何调用SPL脚本有使用和获得它的方法。

关于集算器安装使用、获得免费授权和相关技术资料,可以参见如何使用集算器。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值