时间:2021-05-20
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){ if(map.containsKey(user.getId())){//map中存在此id,将数据存放当前key的map中 map.get(user.getId()).add(user); }else{//map中不存在,新建key,用来存放数据 List<User> tmpList = new ArrayList<>(); tmpList.add(user); map.put(user.getId(), tmpList); } } System.out.println(map.toString()); }执行结果:
可以看到达到了了我们的目的
2、JDK1.8 新特性实现
Map<Integer, List<User>> map = list.stream().collect(Collectors.groupingBy(User::getId));
附上
List<Map<String, Object>>>分组List<Map<String, Object>>> list = new ArrayList<>();Map<Long, List<Map<String, Object>>> contractIdMap = list.stream().collect(Collectors.groupingBy(m -> (Long.parseLong(m.get("contractId").toString()))));Map<Long, List<Map<String, Object>>> nameMap = list.stream().collect(Collectors.groupingBy(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.add(tmp.get(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) tmp.get(oneMapKey);if (oneMapValueStr.equals(oneSetTmpStr)) {oneSetTmpList.add(tmp);}}resultMap.put(oneSetTmpStr, oneSetTmpList);}return resultMap;}以上这篇Java 将List中的实体类按照某个字段进行分组并存放至Map中操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
list按照元素的某个字段去重@Data@AllArgsConstructor@NoArgsConstructorpublicclassStudent{priv
一、sort_values()函数用途pandas中的sort_values()函数原理类似于SQL中的orderby,可以将数据集依照某个字段中的数据进行排序
也许大家有时候会遇到需要将把数据库中的某张表的数据按照该表的某个字段分类输出,比如一张数据表area如下我们需要将里面的area按照serialize字段进行分
博主说:有时候,我们需要对数据库中现有的数据进行大量处理操作(例如表中的某个字段需要全部更新等),如果直接使用select*fromtableName很容易出现
一般来说创建时间和修改时间两个字段是一个实体类必备的。在阿里Java开发手册中也对此的说明:【强制】表必备三字段:id,create_time,update_t