场景

获取到了员工对象的list,每个员工对象有一个部门Id的属性,怎样根据这个部门id实现将这个list进行分组,

使部门id相同的分在一组。

具体实现效果类似于sql 查询中的group by。

实现

首先获取这个对象的list



List<KqsjTian> kqsjTianList = kqsjTianService.tjselectkqsj(kqsjSelectParam);


其中KqsjTian是对象,其有部门id属性



Map<Long, List<KqsjTian>> bmListMap = new HashMap<Long, List<KqsjTian>>();
bmListMap = kqsjTianList.stream().collect(Collectors.groupingBy(kqsjTian -> kqsjTian.getBmid()));


然后调用list的stream方法再调用collect方法,前面声明的map第一个参数是分组的依据。

这里是部门id是long型的,所以第一个参数是Long型的,然后kqsjTian.getBmid()是获取每个对象的部门id属性。

获取分组后的数据的大概数据结构如下

Java中怎样根据对象list的某对象的属性进行分组_程序猿

获取之后就可以遍历这个map进行分别的处理



for (Map.Entry<Long, List<KqsjTian>> entry : bmListMap.entrySet()) {
List<KqsjTian> currnrtbmList = entry.getValue();
for (KqsjTian kqsjTian:currnrtbmList) {
//计算考勤人数
if(kqsjTian.getKqzt()!=null && Constants.KQZT_ZC.contains(kqsjTian.getKqzt()))
{
kqrs++;
}
}
}


每一个entry是一组bmid相同的list,要获取每一个entry的key即部门id



entry.getKey()


获取每个的value



List<KqsjTian> currnrtbmList = entry.getValue();