开发者社区> 韩曙亮> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

【Groovy】json 字符串反序列化 ( 使用 JsonSlurper 进行 json 字符串反序列化 | 根据 map 集合构造相关类 )

简介: 【Groovy】json 字符串反序列化 ( 使用 JsonSlurper 进行 json 字符串反序列化 | 根据 map 集合构造相关类 )
+关注继续查看

一、使用 JsonSlurper 进行 json 字符串反序列化


将如下 json 字符串


{"age":18,"name":"Tom"}


进行反序列化 ;



首先 , 创建 JsonSlurper 对象 ,


def jsonSlurper = new JsonSlurper()


然后 , 调用该 JsonSlurper 对象的 parse 方法 , 可以对不同类型的 json 数据进行反序列化 ;


可进行反序列化的 json 数据类型如下图所示 :

image.png



这里调用 jsonSlurper 对象的 parseText 方法 , 将 json 字符串进行反序列化操作 ;


// 将字符串进行 json 反序列化操作 , 得到 map 集合
def jsonObject = jsonSlurper.parseText('{"age":18,"name":"Tom"}');


打印反序列化结果 ,


// 打印反序列化结果
println jsonObject


执行结果如下 :


[age:18, name:Tom]

二、根据 map 集合构造相关类


在上面的章节将 json 字符串


{"age":18,"name":"Tom"}


进行反序列化 , 得到


[age:18, name:Tom]


map 集合 ;


该 map 集合可以直接赋值给相应类对象 , 该类的变量名就是 map 集合的 Key 键 ;


// 根据 map 集合的 Key 构造类
class Student {
    def name
    def age
}


直接将 map 集合赋值给构造的类对象 , 并打印该对象的成员变量值 ;


// 直接将 map 集合赋值给构造的类对象
Student student = jsonObject
// 打印类对象的成员变量值
println "${student.name} , ${student.age}"


执行结果为 :


Tom , 18

三、完整代码示例


完整代码示例 :


import groovy.json.JsonSlurper
// 将 {"age":18,"name":"Tom"} 字符串进行反序列化
def jsonSlurper = new JsonSlurper()
// 将字符串进行 json 反序列化操作 , 得到 map 集合
def jsonObject = jsonSlurper.parseText('{"age":18,"name":"Tom"}');
// 打印反序列化结果
println jsonObject
// 根据 map 集合的 Key 构造类
class Student {
    def name
    def age
}
// 直接将 map 集合赋值给构造的类对象
Student student = jsonObject
// 打印类对象的成员变量值
println "${student.name} , ${student.age}"


执行结果 :


[age:18, name:Tom]
Tom , 18

image.png

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
使用java将json文件反序列化成java对象
使用java将json文件反序列化成java对象
39 0
使用java将json文件反序列化成java对象
使用java将json文件反序列化成java对象
63 0
JS: json 数据转化为 demo.json 并下载文件
JS: json 数据转化为 demo.json 并下载文件
27 0
PHP传递给js的JSON数据无法反序列化
PHP传递给js的JSON数据无法反序列化
29 0
Django响应JsonResponse返回json格式数据报错
Django响应JsonResponse返回json格式数据报错
27 0
JSON数据构造及解析详解
JSON数据构造及解析详解
167 0
DLA SQL技巧:行、列转换和JSON数据列展开
1. 简介 在数据库SQL处理中,常常有行转列(Pivot)和列转行(Unpivot)的数据处理需求。本文以示例说明在Data Lake Analytics(https://www.aliyun.com/product/datalakeanalytics)中,如何使用SQL的一些技巧,达到行转列(Pivot)和列转行(Unpivot)的目的。
3555 0
JSON数据造假和解析
客户端开发通常要从服务器获取数据,所以就需要调用后台的接口,然后获得后台返回的数据,根据这些数据的格式进行JSON解析。 由于后台返回的数据会有不同的格式,所以前端也要采取不同的JSON.parse()方法进行解析。
816 0
+关注
韩曙亮
专注 Android 领域
文章
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载