场景
获取到了员工对象的list,每个员工对象有一个部门Id的属性,怎样根据这个部门id实现将这个list进行分组,
使部门id相同的分在一组。
具体实现效果类似于sql 查询中的group by。
注:
博客:
https://blog.csdn.net/badao_liumang_qizhi
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。
实现
首先获取这个对象的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();