java通过key-list和对应value更新当前对象
当前有一个复杂对象,类似json,现在要对当前对象进行更新(已有的key更新,未有的key插入)
//递归更新一个json对象,原对象若没有则插入key,精妙! @SuppressWarnings("unchecked") Object setObjectRecursive(Object current, final List<String> paths, int index, final Object value) { // 如果是已经超出path,我们就返回value即可,作为最底层叶子节点 boolean isLastIndex = index == paths.size(); if (isLastIndex) { return value; } String path = paths.get(index).trim(); boolean isNeedMap = isPathMap(path); if (isNeedMap) { Map<String, Object> mapping; // 当前不是map,因此全部替换为map,并返回新建的map对象 boolean isCurrentMap = current instanceof Map; if (!isCurrentMap) { mapping = new HashMap<String, Object>(); mapping.put( path, buildObject(paths.subList(index + 1, paths.size()), value)); return mapping; } // 当前是map,但是没有对应的key,也就是我们需要新建对象插入该map,并返回该map mapping = ((Map<String, Object>) current); boolean hasSameKey = mapping.containsKey(path); if (!hasSameKey) { mapping.put(path,buildObject(paths.subList(index + 1, paths.size()), value)); return mapping; } // 当前是map,而且还竟然存在这个值,好吧,继续递归遍历 current = mapping.get(path); mapping.put(path, setObjectRecursive(current, paths, index + 1, value)); return mapping; } boolean isNeedList = isPathList(path); if (isNeedList) { List<Object> lists; int listIndexer = getIndex(path); // 当前是list,直接新建并返回即可 boolean isCurrentList = current instanceof List; if (!isCurrentList) { lists = expand(new ArrayList<Object>(), listIndexer + 1); lists.set( listIndexer, buildObject(paths.subList(index + 1, paths.size()), value)); return lists; } // 当前是list,但是对应的indexer是没有具体的值,也就是我们新建对象然后插入到该list,并返回该List lists = (List<Object>) current; lists = expand(lists, listIndexer + 1); boolean hasSameIndex = lists.get(listIndexer) != null; if (!hasSameIndex) { lists.set( listIndexer, buildObject(paths.subList(index + 1, paths.size()), value)); return lists; } // 当前是list,并且存在对应的index,没有办法继续递归寻找 current = lists.get(listIndexer); lists.set(listIndexer, setObjectRecursive(current, paths, index + 1, value)); return lists; } throw DataMException.asDataMException("该异常代表系统编程错误, 请联系DataX开发团队"); } //根据key的类型来选择获取value的方式 private boolean isPathMap(final String path) { return StringUtils.isNotBlank(path) && !isPathList(path); } private boolean isPathList(final String path) { return path.contains("[") && path.contains("]"); }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗
2019-12-25 python单例模式
2019-12-25 python反射
2019-12-25 python面向对象——常用内置方法
2019-12-25 python类对象动态添加属性和方法
2019-12-25 python用类实现装饰器