Java中怎樣根據對象list的某對象的屬性進行分組


場景

獲取到了員工對象的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();


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM