詳解Java8的groupBy實現集合的分組
場景:
Java8的groupBy實現集合的分組,類似Mysql的group by分組功能,註意得到的是一個map
1.對集合按照單個屬性分組
e.g. 按照skuId分組
Map<String, List<EntryDeliveryDetailywk>> detailsMap01 = dtos1.stream() .collect(Collectors.groupingBy(EntryDeliveryDetailywk::getskuId));
2對集合按照多個屬性分組
solution 1 多個屬性拼接出一個組合屬性
將多個字段拼接成一個新字段,在使用Java8的groupBy進行分組
Map<String, List<EntryDeliveryDetailywk>> detailmap = details.stream() .collect(Collectors.groupingBy(d -> fetchGroupKey(d) )); private String fetchGroupKey(EntryDeliveryDetailywk detail){ return detail.getSkuId().toString() + detail.getItemsName() + detail.getWarehouseId().toString() + detail.getSupplierId().toString(); }
solution 2 造靜態內部類
在集合元素類裡構造靜態內部類(成員變量即分組的對應多個屬性)
e.g.
//靜態內部類 class Person { public static class NameAge { public NameAge(String name, int age) { ... } // 註意 重寫方法 must implement equals and hash function } public NameAge getNameAge() { return new NameAge(name, age); } } //分組 Map<NameAge, List<Person>> map = people.collect(Collectors.groupingBy(Person::getNameAge));
solution 3 嵌套調用Java8 groupby
註意得到也是嵌套map
Map<String, Map<Integer, List<Person>>> map = people .collect(Collectors.groupingBy(Person::getName, Collectors.groupingBy(Person::getAge)); //調用 map.get("Fred").get(18);
參考
https://stackoverflow.com/questions/28342814/group-by-multiple-field-names-in-java-8
到此這篇關於詳解Java8的groupBy實現集合的分組的文章就介紹到這瞭,更多相關Java8 groupBy集合分組內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Java8 中的ParallelStreams
- java8中的Collectors.groupingBy用法詳解
- Java8 實現stream將對象集合list中抽取屬性集合轉化為map或list
- Java8中Stream的詳細使用方法大全
- java8實現List中對象屬性的去重方法