ObjectMapper 解析 json

2023-10-14 21:59
文章标签 json 解析 objectmapper

本文主要是介绍ObjectMapper 解析 json,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先,net.sf.json.JSONObject.fromObject(json),解析josn字符串的时候,会存在浮点型数据误差的问题,如534733.92解析成
534733.94。建议使用 ObjectMapper

问题描述,在使用 ObjectMapper解析json数据的时候,json数据太多,只想解析需要的数据生成pojo对象。

解析的Class为Map, 可以先使用Object.class ,调试之后发现是 linkedHashMap类型。

        Map map = objectMapper.readValue(json, Map.class);Object emp = map.get("empList");ArrayList<LinkedHashMap> list = (ArrayList<LinkedHashMap>)emp;LinkedHashMap linkedHashMap = list.get(0);System.out.println(linkedHashMap.get("ename"));

 例,ParamVo中有empList,入参为 ParamVo生成的json字符串,如何只解析 empList 中的数据,转成对应的pojo对象。

public class MyTest {public static void main(String[] args) throws Exception{ObjectMapper objectMapper = new ObjectMapper();ParamVo paramVo = new ParamVo();paramVo.setCode("200");paramVo.setMesage("成功");List<Emp> emps = new ArrayList<>();emps.add(new Emp(1001,"zhangsan","java", new BigDecimal("10"),10));emps.add(new Emp(1003,"zhaoliu","php", new BigDecimal("30"),30));paramVo.setEmpList(emps);paramVo.setEmp(new Emp(1002,"lisi","c++", new BigDecimal("20"),20));//解析 ParamVo paramVo = new ParamVo(); 生成的json//paramVo========={"mesage":"成功","emp":{"empno":1002,"ename":"lisi","job":"c++","mgr":null,"hiredate":null,"sal":20,"comm":null,"deptno":20},"empList":[{"empno":1001,"ename":"zhangsan","job":"java","mgr":null,"hiredate":null,"sal":10,"comm":null,"deptno":10},{"empno":1003,"ename":"zhaoliu","job":"php","mgr":null,"hiredate":null,"sal":30,"comm":null,"deptno":30}]}String json = objectMapper.writeValueAsString(paramVo);System.out.println("paramVo========="+json);ParamVo paramVo1 = objectMapper.readValue(json, ParamVo.class);//解析 List<Emp> emps = new ArrayList<>(); 生成的json//empsString======[{"empno":1001,"ename":"zhangsan","job":"java","mgr":null,"hiredate":null,"sal":10,"comm":null,"deptno":10},{"empno":1003,"ename":"zhaoliu","job":"php","mgr":null,"hiredate":null,"sal":30,"comm":null,"deptno":30}]String empsString = objectMapper.writeValueAsString(emps);System.out.println("empsString======"+empsString);JavaType javaType = objectMapper.getTypeFactory().constructParametricType(List.class, Emp.class);List<Emp> list = objectMapper.readValue(empsString, javaType);//入参的 json 为 ParamVo paramVo = new ParamVo(); 生成的json,但是内容太多,只想解析 empList 的内容,转成对应的pojo//思路,可以通过 Object object = objectMapper.readValue(json, Object.class); debug查看该json生成的数据结构,发现是LinkedHashMapMap map = objectMapper.readValue(json, Map.class);Object emp = map.get("empList");ArrayList<LinkedHashMap> empList = (ArrayList<LinkedHashMap>)emp;for(int i=0;i<empList.size();i++){LinkedHashMap linkedHashMap = empList.get(i);System.out.println(linkedHashMap.toString());//{empno=1001, ename=zhangsan, job=java, mgr=null, hiredate=null, sal=10, comm=null, deptno=10}//{empno=1003, ename=zhaoliu, job=php, mgr=null, hiredate=null, sal=30, comm=null, deptno=30}//已经拿到 empList 的map数据,就可以转换成pojo了}}
}

 

这篇关于ObjectMapper 解析 json的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/213409

相关文章

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

数据库使用之union、union all、各种join的用法区别解析

《数据库使用之union、unionall、各种join的用法区别解析》:本文主要介绍SQL中的Union和UnionAll的区别,包括去重与否以及使用时的注意事项,还详细解释了Join关键字,... 目录一、Union 和Union All1、区别:2、注意点:3、具体举例二、Join关键字的区别&php

Spring IOC控制反转的实现解析

《SpringIOC控制反转的实现解析》:本文主要介绍SpringIOC控制反转的实现,IOC是Spring的核心思想之一,它通过将对象的创建、依赖注入和生命周期管理交给容器来实现解耦,使开发者... 目录1. IOC的基本概念1.1 什么是IOC1.2 IOC与DI的关系2. IOC的设计目标3. IOC