Java将List中的实体类按照某个字段进⾏分组并存放⾄Map中
操作
1、JDK1.8之前:
假设有实体类User,⾥⾯有字段id,我们将相同id的User进⾏分组,并存放在Map中。(例⼦不是很恰当,但很能说明问题)
public static void main(String[] args) {
List<User> list = new ArrayList<>();
list.add(new User(1, 1));
list.add(new User(1, 2));
list.add(new User(2, 1));
list.add(new User(2, 3));
list.add(new User(2, 2));
list.add(new User(3, 1));
Map<Integer, List<User>> map = new HashMap<>();
for(User user : list){
Id())){//map中存在此id,将数据存放当前key的map中
<(Id()).add(user);
}else{//map中不存在,新建key,⽤来存放数据
List<User> tmpList = new ArrayList<>();
tmpList.add(user);
map.Id(), tmpList);
}
}
System.out.String());
}
执⾏结果:
可以看到达到了了我们的⽬的
2、JDK1.8 新特性实现
Map<Integer, List<User>> map = list.stream().upingBy(User::getId));
附上
List<Map<String, Object>>>分组
List<Map<String, Object>>> list = new ArrayList<>();
Map<Long, List<Map<String, Object>>> contractIdMap =
list.stream().upingBy(m -> (Long.("contractId").toString()))));
Map<Long, List<Map<String, Object>>> nameMap =
list.stream().upingBy(m -> (m.get("name").toString())));
补充知识:java中对list的数据按照某个属性进⾏分组,拆分成多个list
我就废话不多说了,⼤家还是直接看代码吧~
/**
* 按照List<Map<String,Object>>⾥⾯map的某个value重新封装成多个不同的list, 原始数据类型List<Map
* <String,Object>>, 转换后数据类型Map<String,List<Map<String,Object>>>
*
* @param list
* @param oneMapKey
* @return
*/
private static Map<String, Object> change(List<Map<String, Object>> list, String oneMapKey) {
Map<String, Object> resultMap = new HashMap<String, Object>();
Set setTmp = new HashSet();
for (Map<String, Object> tmp : list) {
setTmp.(oneMapKey));
}
Iterator it = setTmp.iterator();
while (it.hasNext()) {
String oneSetTmpStr = (String) it.next();
List<Map<String, Object>> oneSetTmpList = new ArrayList<Map<String, Object>>();
for (Map<String, Object> tmp : list) {
String oneMapValueStr = (String) (oneMapKey);
if (oneMapValueStr.equals(oneSetTmpStr)) {
oneSetTmpList.add(tmp);
}
}
resultMap.put(oneSetTmpStr, oneSetTmpList);
}
后端字符串转数组return resultMap;
}
以上这篇Java 将List中的实体类按照某个字段进⾏分组并存放⾄Map中操作就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。