话不多说,看代码和效果
/**
* 根据map中的某个key 去除List中重复的map
* @author shijing
* @param list
* @param mapKey
* @return
*/
public static List<Map<String, >> removeRepeatMapByKey(List<Map<String, >>
list, String mapKey){
if (CollectionUtils.isNullOrEmpty(list)) return null;
//把list中的数据转换成msp,去掉同一id值多余数据,保留查找到第一个id值对应的数据
List<Map<String, >> listMap = new ArrayList<>();
Map<String, Map> msp = new HashMap<>();
for(int i = list.size()-1 ; i>=0; i--){
Map map = list.get(i);
String id = (String)map.get(mapKey);
map.remove(mapKey);
msp.put(id, map);
}
//把msp再转换成list,就会得到根据某一字段去掉重复的数据的List<Map>
Set<String> mspKey = msp.keySet();
for(String key: mspKey){
Map newMap = msp.get(key);
newMap.put(mapKey, key);
listMap.add(newMap);
}
return listMap;
}
测试:
public static void main(String[] args) {
Map<String, Map> msp = new HashMap<String, Map>();
List<Map<String, >> list = new ArrayList<Map<String, >>();
List<Map<String, >> listMap = new ArrayList<Map<String, >>();
Map<String, > map1 = new HashMap<String, >();
map1.put(\"id\", \"1123\");
map1.put(\"name\", \"张三\");
Map<String, > map2 = new HashMap<String, >();
map2.put(\"id\", \"2\");
map2.put(\"name\", \"李四\");
Map<String, > map3 = new HashMap<String, >();
map3.put(\"id\", \"1123\");
map3.put(\"name\", \"王五\");
Map<String, > map4 = new HashMap<String, >();
map4.put(\"id\", \"3\");
map4.put(\"name\", \"赵六\");
list.add(map1);
list.add(map2);
list.add(map3);
list.add(map4);
System.out.println(\"初始数据:\" + list.toString());
System.out.println(\"去重之后:\" + removeRepeatMapByKey(list,\"id\"));
}
结果:
初始数据:[{name=张三, id=1123}, {name=李四, id=2}, {name=王五, id=1123}, {name=赵六, id=3}]
去重之后:[{name=李四, id=2}, {name=赵六, id=3}, {name=张三, id=1123}]
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
继续阅读与本文标签相同的文章
上一篇 :
thinkPHP框架实现的简单计算器示例
下一篇 :
AlphaZero:通用型的棋类人工智能程序
-
35个Java代码优化的细节,你知道几个?
2026-05-19栏目: 教程
-
[译] 作为程序员你不能成功的 10 个迹象
2026-05-19栏目: 教程
-
[译] 从没有人告诉过我的 CSS 小知识
2026-05-19栏目: 教程
-
[译] Android 生命周期备忘录 — 第三部分:Fragments
2026-05-19栏目: 教程
-
[译] 多线程简介:一步一步来接近多线程的世界
2026-05-19栏目: 教程
