Java嵌入脚本怎么快速解析多层 json

技术Java嵌入脚本怎么快速解析多层 jsonJava嵌入脚本怎么快速解析多层 json,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。关于Json处理的开源

对于如何用Java嵌入式脚本快速解析多层json,相信很多没有经验的人都是一窍不通的。为此,本文总结了问题产生的原因和解决方法,希望大家可以通过这篇文章来解决这个问题。

有很多关于Json处理的开源包,比如json-lib、jackson、Gson和Fastjson。Gson是谷歌做的,功能强大;Fastjson是阿里巴巴做的,性能很快。用哪一个,只要你开心就好。

解析Json一般是为了重新计算。这些常见的开源包大多为读取和解析Json提供了丰富的接口。但如何将多层Json数据过滤、深度计算、扩展为二维数据用于其他服务,仍然需要复杂的硬编码,一般需要关系数据库的帮助(创建临时表、解析入库,然后使用SQL进行二次操作等)。).当这些步骤完成后,开发人员需要头疼。

比如处理这样一个场景:订单信息的Json数据分为两层:第一层是国家和地区,第二层是详细数据。现在想了解一下2013年华北地区的订单情况。

一些源数据如下:

[{'COUNTRY':'China ',' AREA': '东北',' ORDERS':[

{'ORDER_ID':10252,' CUSTOMER_ID':'SUPRD ',' EMPLOYEE_ID':4,…},

{ '订单标识' :10318,'客户标识' :'ISLAT ','员工标识' :8,…},

…]},

{'COUNTRY':'China ',' AREA': '华东',' ORDERS':[

{'ORDER_ID':10249,' CUSTOMER_ID':'TOMSP ',' EMPLOYEE_ID':6,…},

{'ORDER_ID':10251,' CUSTOMER_ID':'VICTE ',' EMPLOYEE_ID':3,…},

…]},

…]

期待Json结构化和过滤的效果:

COUNTRY

AREA

ORDER_ID

CUSTOMER_ID

EMPLOYEE_ID

ORDER_DATE

中国

华北

10402

ERNSH

2013-01-02

中国

华北

10403

ERNSH

2013-01-03

中国

华北

10404

MAGAA

2

2013-01-03

中国

华北

10407

OTTIK

2

2013-01-07

Java解析代码的一部分应该编写如下:

.

JSON object JSON object=JSON object . from object(order str);

JSON array JSON array=JSON object . getjson array(' COUNTRY ');

.

JSONArray two=JSONArray . getjsonarray(' ORDERS ');

JSONObject two=null

ListMapString,String list=new ArrayListMapString,String();

for(int I=0;I two . size();I){ 0

two=two . Getjsonobject(I);

MapString,String map=new HashMapString,String();

.

list . add(map);

}

.

如果有set运算符,那么Json解析将会简单得多。它不仅两次封装了Json类库,而且实现同样的算法所需的代码更少。而且在集合操作领域精心设计了一套函数库来应对各种结构化操作,不再需要安装配置第三方数据库软件。例如,从解析到过滤,只需要4行就可以完成:

A

一个

=json(文件(' orders.json ')。read())

2

=a1 . select(COUNTRY==' China ' area . contain('华北')

=A2 . news(ORDERS;国家,地区,${B1。ORDERS.fname()。concat@c()})

=A3.select(年份(ORDER_DATE)==2013)

看完以上内容,你掌握了如何用Java嵌入式脚本快速解析多层json了吗?如果您想学习更多技能或了解更多相关内容,请关注行业资讯频道,感谢您的阅读!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/131712.html

(0)

相关推荐

  • 对Mysql的MVCC的理解是什么

    技术对Mysql的MVCC的理解是什么今天就跟大家聊聊有关对Mysql的MVCC的理解是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。MVCC(Mutil-V

    攻略 2021年10月25日
  • 医保跨省转移,如何异地转移社保和医保

    技术医保跨省转移,如何异地转移社保和医保医保跨省转移手续:首先要在原参保地办理医疗保险关系注销手续,然后由本人向市社保中心提出医疗保险关系转移申请医保跨省转移;凭转出地经办机构出具的《参保(合)凭证》以及原参保地医疗保险

    生活 2021年10月31日
  • 什么是nodejs模块

    技术什么是nodejs模块本篇内容介绍了“什么是nodejs模块”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

    2021年10月29日
  • 面试官:你给我说一下线程池里面的几个锁吧。

    技术面试官:你给我说一下线程池里面的几个锁吧。 面试官:你给我说一下线程池里面的几个锁吧。你好呀,我是歪歪。
    最近有个读者给我说,面试聊到线程池的时候,相谈甚欢,基本都回答上来了,但是其中有一个问题直接

    礼包 2021年11月1日
  • Vue开发必须知道的技巧有哪些

    技术Vue开发必须知道的技巧有哪些这篇文章主要介绍“Vue开发必须知道的技巧有哪些”,在日常操作中,相信很多人在Vue开发必须知道的技巧有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”

    攻略 2021年10月20日
  • Scala简化代码的方法是什么

    技术Scala简化代码的方法是什么本篇内容介绍了“Scala简化代码的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有

    攻略 2021年12月10日