博客
关于我
Java中递归遍历Map数据,并替换值为null的数据
阅读量:785 次
发布时间:2019-03-25

本文共 2008 字,大约阅读时间需要 6 分钟。

项目需求分析与解决方案

当前需求针对一个JSON数据格式的处理,要求对内部结构中出现"null"值进行替换,替换为空间实137020。数据结构为:

{  "TYPE": "FLIGHTLOAD",  "DATA": {    "FLIGHTID": {      "OUTERFLIGHTID": "6A9DF3F551060192E0530B061C20F1C1",      "CARRIER": "MF",      "FLIGHT": "null",      "ORIGIN": "PEK",      "DESTINATION": "XMN",      "SCHEDULEDEPARTURETIME": "20190312160500"    },    "PAYLOAD": [      {        "DEPARTUREAIRPORT": "PEK",        "DESTINATIONAIRPORT": "XMN",        "TRANSITCHILD": "null",        "TRANSITINFANT": "null",        "BAGGAGE": "959",        "BAGGAGECOUNT": "959",        "POST": "0",        "CARGO": "1859",        "TRANSITPOST": "null",        "TRANSITCARGO": "null"      }    ]  }

工具与解决方案

为了实现上述需求,我们开发了一套递归处理方法,该方法能够将JSON数据中的"null"值替换为空。具体实现如下:

public static void mapNullToEmpty(Map
jsonResult) { for (Map.Entry
entry : jsonResult.entrySet()) { String key = entry.getKey(); Object obj = entry.getValue(); if (obj instanceof String) { if ("null".equals(obj)) { jsonResult.put(key, ""); } } else if (obj instanceof List) { List
> dataList = (List
>) obj; for (Map
data : dataList) { mapNullToEmpty(data); } } else if (obj instanceof Map) { mapNullToEmpty((Map
) obj); } }}

实施效果

经过处理后的JSON数据结构如下:

{  "TYPE": "FLIGHTLOAD",  "DATA": {    "FLIGHTID": {      "OUTERFLIGHTID": "6A9DF3F551060192E0530B061C20F1C1",      "CARRIER": "MF",      "FLIGHT": "",      "ORIGIN": "PEK",      "DESTINATION": "XMN",      "SCHEDULEDEPARTURETIME": "20190312160500"    },    "PAYLOAD": [      {        "DEPARTUREAIRPORT": "PEK",        "DESTINATIONAIRPORT": "XMN",        "TRANSITCHILD": "",        "TRANSITINFANT": "",        "BAGGAGE": "959",        "BAGGAGECOUNT": "959",        "POST": "0",        "CARGO": "1859",        "TRANSITPOST": "",        "TRANSITCARGO": ""      }    ]  }}

项目总结

该方案通过递归处理JSON数据,实现了将"null"值替换为空的需求。在实际应用中,需要注意以下几点:

  • 确保处理方法能够覆盖所有嵌套的JSON结构
  • 注意保持原始数据的其他不变性
  • 要严格按照项目需求对"null"值进行替换
  • 在处理后期性能有所增加
  • 这种方法能够灵活适配不同层级的JSON数据,同时确保代码简洁且易于维护。

    转载地址:http://xapuk.baihongyu.com/

    你可能感兴趣的文章
    Mysql学习总结(53)——使用MySql开发的Java开发者规范
    查看>>
    Mysql学习总结(54)——MySQL 集群常用的几种高可用架构方案
    查看>>
    Mysql学习总结(55)——MySQL 语句大全再温习
    查看>>
    Mysql学习总结(56)——MySQL用户管理和权限设置
    查看>>
    Mysql学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
    查看>>
    Mysql学习总结(58)——深入理解Mysql的四种隔离级别
    查看>>
    Mysql学习总结(59)——数据库分库分表策略总结
    查看>>
    Mysql学习总结(5)——MySql常用函数大全讲解
    查看>>
    Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
    查看>>
    Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
    查看>>
    Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
    查看>>
    Mysql学习总结(63)——Mysql数据库架构方案选择与分析
    查看>>
    Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
    查看>>
    Mysql学习总结(65)——项目实战中常用SQL实践总结
    查看>>
    Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
    查看>>
    Mysql学习总结(67)——MYSQL慢查询日志
    查看>>
    Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
    查看>>
    Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
    查看>>
    Mysql学习总结(6)——MySql之ALTER命令用法详细解读
    查看>>
    Mysql学习总结(70)——MySQL 优化实施方案
    查看>>