获取到了员工对象的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属性。
获取分组后的数据的大概数据结构如下
获取之后就可以遍历这个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();