解决Map修改key的问题

news/2025/1/15 23:03:14/

需求

现在返回json数据带有分页的数据,将返回data属性数据变更为content,数据不变,key发生变化

在这里插入图片描述

实现1,源数据比较复杂,组装数据比较麻烦

说明:如果使用这种方式完成需求,需要创建对象,一个和PageInfo一样的对象,list属性修改为content,其他拷贝过去就行了。
但是,如果数据量10w左右,还是按照这种方式,json转换比较耗时,这种方式虽然麻烦,效率快一点。

    @Testpublic void t2(){log.info("需求:k1变为k2,value不变");Map<String, Object> map = new HashMap<>();map.put("k1","v1");log.info("修改前");for (Map.Entry<String, Object> entry : map.entrySet()) {log.info("key:【{}】,value:【{}】",entry.getKey(),entry.getValue());}String pendingItem  = map.get("k1").toString();map.remove("k1");map.put("k2",pendingItem);log.info("修改后");for (Map.Entry<String, Object> entry : map.entrySet()) {log.info("key:【{}】,value:【{}】",entry.getKey(),entry.getValue());}}

Connected to the target VM, address: ‘127.0.0.1:5463’, transport: ‘socket’
20:12:41.966 [main] INFO com.geekmice.springbootselfexercise.NoDaoTest - 需求:k1变为k2,value不变
20:12:41.984 [main] INFO com.geekmice.springbootselfexercise.NoDaoTest - 修改前
20:12:41.984 [main] INFO com.geekmice.springbootselfexercise.NoDaoTest - key:【k1】,value:【v1】
20:12:41.989 [main] INFO com.geekmice.springbootselfexercise.NoDaoTest - 修改后
20:12:41.990 [main] INFO com.geekmice.springbootselfexercise.NoDaoTest - key:【k2】,value:【v1】
Disconnected from the target VM, address: ‘127.0.0.1:5463’, transport: ‘socket’
在这里插入图片描述

实现2,通过工具类json转换,注意数据量大时候不建议使用

        String listSTR = "{\n" +"\t\t\"startRow\": 3,\n" +"\t\t\"navigatepageNums\": [1, 2],\n" +"\t\t\"prePage\": 1,\n" +"\t\t\"hasNextPage\": false,\n" +"\t\t\"nextPage\": 0,\n" +"\t\t\"pageSize\": 2,\n" +"\t\t\"endRow\": 3,\n" +"\t\t\"list\": [{\n" +"\t\t\t\"teacherName\": \"小2\",\n" +"\t\t\t\"teacherNo\": \"6\",\n" +"\t\t\t\"categoryId\": 9999\n" +"\t\t}],\n" +"\t\t\"pageNum\": 2,\n" +"\t\t\"navigatePages\": 8,\n" +"\t\t\"total\": 3,\n" +"\t\t\"navigateFirstPage\": 1,\n" +"\t\t\"pages\": 2,\n" +"\t\t\"size\": 1,\n" +"\t\t\"isLastPage\": true,\n" +"\t\t\"hasPreviousPage\": true,\n" +"\t\t\"navigateLastPage\": 2,\n" +"\t\t\"isFirstPage\": false\n" +"\t}";JSONObject jsonObject1 = JSONObject.parseObject(listSTR);Object newList = jsonObject1.get("list");jsonObject1.remove("list");jsonObject1.put("content", newList);

list属性转换为data属性
在这里插入图片描述
在这里插入图片描述
注:如果有更好的方式,希望大家多多指教。


http://www.ppmy.cn/news/1010055.html

相关文章

Vue3 条件渲染简单应用

去官网学习-》条件渲染 | Vue.js 运行示例&#xff1a; 代码&#xff1a;HelloWorld.vue <template><div class"hello"><h1>Vue 条件渲染</h1><h2 v-if"flag">true显示内容</h2><h2 v-if"flag2">fal…

《吐血整理》高级系列教程-吃透Fiddler抓包教程(33)-Fiddler如何抓取WebSocket数据包

1.简介 本来打算再写一篇这个系列的文章也要和小伙伴或者童鞋们说再见了&#xff0c;可是有人留言问WebSocket包和小程序的包不会抓&#xff0c;那就关于这两个知识点宏哥就再水两篇文章。 2.什么是Socket&#xff1f; 在计算机通信领域&#xff0c;socket 被翻译为“套接字…

JavaScript |(七)BOM及JSON简介 | 轮播图 | 尚硅谷JavaScript基础实战

学习来源&#xff1a;尚硅谷JavaScript基础&实战丨JS入门到精通全套完整版 系列笔记&#xff1a; JavaScript |&#xff08;一&#xff09;JavaScript简介及基本语法JavaScript |&#xff08;二&#xff09;JavaScript自定义对象及函数JavaScript |&#xff08;三&#xff…

P1833 樱花(多重背包)(内附封面)

樱花 题目背景 《爱与愁的故事第四弹plant》第一章。 题目描述 爱与愁大神后院里种了 n n n 棵樱花树&#xff0c;每棵都有美学值 C i ( 0 ≤ C i ≤ 200 ) C_i(0 \le C_i \le 200) Ci​(0≤Ci​≤200)。爱与愁大神在每天上学前都会来赏花。爱与愁大神可是生物学霸&#…

基于历史对比学习的时序知识图谱推理(AAAI2023)

知识图谱顶会小记 论文标题 Temporal Knowledge Graph Reasoning with Historical Contrastive Learning 论文链接 https://arxiv.org/pdf/2211.10904.pdf GitHub地址 https://github.com/xyjigsaw/CENET 关键词 Linked Open Data, Knowledge Graphs & KB Completi…

auto-changelog的简单使用

auto-changelog的简单使用 自动化生成Git提交记录&#xff0c;CHANGELOG.md文件 github&#xff1a;https://github.com/cookpete/auto-changelog 安装 npm install -g auto-changelog配置脚本 package.json文件下 "scripts": {"changelog": "aut…

webpack基础知识六:说说webpack的热更新是如何做到的?原理是什么?

一、是什么 HMR全称 Hot Module Replacement&#xff0c;可以理解为模块热替换&#xff0c;指在应用程序运行过程中&#xff0c;替换、添加、删除模块&#xff0c;而无需重新刷新整个应用 例如&#xff0c;我们在应用运行过程中修改了某个模块&#xff0c;通过自动刷新会导致…

-bash: ./startup.sh: Permission denied解决

今天在Linux上启动Tomcat&#xff0c;结果弹出&#xff1a;-bash: ./startup.sh: Permission denied 的提示。 这是因为用户没有权限&#xff0c;而导致无法执行。用命令chmod 修改一下bin目录下的.sh权限就可以了。 在Tomcat的bin目录下 &#xff0c;输入命令行 &#xff1a;c…