如何解析一个树形结构的json

本文讨论了如何处理从服务器获取的树形结构JSON数据。解析JSON时,通常使用FastJson或Gson库。面对不同节点类型的情况,提出了两种处理方式:1) 合并所有children数据到一个类;2) 使用HashMap存储children数据,通过递归遍历。对于复杂的层级和多变的属性,递归方法更具灵活性,但如何展示和取值仍是挑战。作者提出根据后台返回的type字段动态取值,并欢迎读者交流更好的解决方案。
摘要由CSDN通过智能技术生成

8b844ed36ce6d29e636e2d076b16f003.gif

691326efcfa2c56ebf76b6fb3845bfdd.png

972a009d1b54eefb6cbd5774947d75c3.png

树形json数据的解析

关于树形结构的数据,在工作的项目中用的还是比较多的。从服务器上获取到的数据往往都是json格式的,这个时候就需要我们去对json数据进行解析。

树形结构介绍。

df85446049ad7e387c8fccf18f49b57b.png

ebc830ce7537219867464bfa5b1ac45d.png

如何解析json数据

关于json数据的解析,我们为什么要进行json数据的解析的,因为在java中或者其他的语言中,从服务器拿到的数据是json的字符串。我们不能通过这个String来获取对我们有用的数据。

在项目中,往往采用FastJson或者Gson解析。

  • FastJson

6a216ced6f0aa341f4b15aa9dcd55cfe.png

  • Gson

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用递归的方式来遍历JSON树形结构。在给定的代码中,listest方法使用了递归来遍历JSON对象。首先,将JSON字符串解析JSONObject对象,然后使用entrySet()方法获取JSON对象的键值对集合。接下来,遍历键值对集合,对于每个键值对,判断值是否为空,如果为空则跳过。然后,使用testIsObject方法判断值是否为对象,如果是对象,则递归调用listest方法。如果不是对象,则打印键和值。这样就可以遍历整个JSON树形结构了。\[1\] 另外,如果想要封装JSON数据到实体类中,可以新建一个实体类来封装JSON数据。在给定的代码中,可以使用@Data、@AllArgsConstructor和@NoArgsConstructor注解来简化实体类的定义。在实体类中定义与JSON字段对应的属性,然后通过调用JSONObject的get方法来获取对应的值,并将值赋给实体类的属性。\[2\] 如果想要获取result中的data信息,可以使用getJSONArray方法来获取data字段对应的JSONArray对象。然后可以对JSONArray进行遍历,获取每个元素的值。\[3\] #### 引用[.reference_title] - *1* [在Java中遍历json树结构](https://blog.csdn.net/jiaowo_ccc/article/details/79759399)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Java递归遍历JSON的N叉树数据结构](https://blog.csdn.net/ELSA001/article/details/126344463)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值