Stream Collectors groupingBy 例子
来源:互联网 发布:js div模态框 编辑:程序博客网 时间:2024/04/27 13:31
在这篇文章中,我们将向您展示如何使用java 8 Stream Collectors
对列表分组,计数,求和和排序。
1. Group By, Count and Sort
1.1 Group by a List
and display the total count of it.(按列表分组,并显示其总数)
Java8Example1.java
package com.mkyong.java8;import java.util.Arrays;import java.util.List;import java.util.Map;import java.util.function.Function;import java.util.stream.Collectors;public class Java8Example1 { public static void main(String[] args) { //3 apple, 2 banana, others 1 List<String> items = Arrays.asList("apple", "apple", "banana", "apple", "orange", "banana", "papaya"); Map<String, Long> result = items.stream().collect( Collectors.groupingBy( Function.identity(), Collectors.counting() ) ); System.out.println(result); }}
output
{papaya=1, orange=1, banana=2, apple=3}
1.2 Add sorting.(增加排序实现)
Java8Example2.java
package com.mkyong.java8;import java.util.Arrays;import java.util.LinkedHashMap;import java.util.List;import java.util.Map;import java.util.function.Function;import java.util.stream.Collectors;public class Java8Example2 { public static void main(String[] args) { //3 apple, 2 banana, others 1 List<String> items = Arrays.asList("apple", "apple", "banana", "apple", "orange", "banana", "papaya"); Map<String, Long> result = items.stream().collect( Collectors.groupingBy( Function.identity(), Collectors.counting() ) ); Map<String, Long> finalMap = new LinkedHashMap<>(); //Sort a map and add to finalMap result.entrySet().stream() .sorted(Map.Entry.<String, Long>comparingByValue() .reversed()).forEachOrdered(e -> finalMap.put(e.getKey(), e.getValue())); System.out.println(finalMap); }}
output
{apple=3, banana=2, papaya=1, orange=1}
2. List Objects
Examples to ‘group by’ a list of user defined Objects.(通过“用户定义的对象”列表进行分组的示例。)
2.1 A Pojo.
Item.java
package com.mkyong.java8;import java.math.BigDecimal;public class Item { private String name; private int qty; private BigDecimal price; //constructors, getter/setters}
2.2 Group by the name + Count or Sum the Qty. (name + Count分组或者 对 Qty求和分组)
Java8Examples3.java
package com.mkyong.java8;import java.math.BigDecimal;import java.util.Arrays;import java.util.List;import java.util.Map;import java.util.stream.Collectors;public class Java8Examples3 { public static void main(String[] args) { //3 apple, 2 banana, others 1 List<Item> items = Arrays.asList( new Item("apple", 10, new BigDecimal("9.99")), new Item("banana", 20, new BigDecimal("19.99")), new Item("orang", 10, new BigDecimal("29.99")), new Item("watermelon", 10, new BigDecimal("29.99")), new Item("papaya", 20, new BigDecimal("9.99")), new Item("apple", 10, new BigDecimal("9.99")), new Item("banana", 10, new BigDecimal("19.99")), new Item("apple", 20, new BigDecimal("9.99")) ); Map<String, Long> counting = items.stream().collect( Collectors.groupingBy(Item::getName, Collectors.counting())); System.out.println(counting); Map<String, Integer> sum = items.stream().collect( Collectors.groupingBy(Item::getName, Collectors.summingInt(Item::getQty))); System.out.println(sum); }}
output
//Group by + Count{papaya=1, banana=2, apple=3, orang=1, watermelon=1}//Group by + Sum qty{papaya=20, banana=30, apple=40, orang=10, watermelon=10}
2.2 Price 分组 – Collectors.groupingBy
and Collectors.mapping
例子.
Java8Examples4.java
package com.mkyong.java8;import java.math.BigDecimal;import java.util.Arrays;import java.util.List;import java.util.Map;import java.util.Set;import java.util.stream.Collectors;public class Java8Examples4 { public static void main(String[] args) { //3 apple, 2 banana, others 1 List<Item> items = Arrays.asList( new Item("apple", 10, new BigDecimal("9.99")), new Item("banana", 20, new BigDecimal("19.99")), new Item("orang", 10, new BigDecimal("29.99")), new Item("watermelon", 10, new BigDecimal("29.99")), new Item("papaya", 20, new BigDecimal("9.99")), new Item("apple", 10, new BigDecimal("9.99")), new Item("banana", 10, new BigDecimal("19.99")), new Item("apple", 20, new BigDecimal("9.99")) );//group by price Map<BigDecimal, List<Item>> groupByPriceMap =items.stream().collect(Collectors.groupingBy(Item::getPrice)); System.out.println(groupByPriceMap);// group by price, uses 'mapping' to convert List<Item> to Set<String> Map<BigDecimal, Set<String>> result = items.stream().collect( Collectors.groupingBy(Item::getPrice, Collectors.mapping(Item::getName, Collectors.toSet()) ) ); System.out.println(result); }}
output
{19.99=[Item{name='banana', qty=20, price=19.99}, Item{name='banana', qty=10, price=19.99}], 29.99=[Item{name='orang', qty=10, price=29.99}, Item{name='watermelon', qty=10, price=29.99}], 9.99=[Item{name='apple', qty=10, price=9.99}, Item{name='papaya', qty=20, price=9.99}, Item{name='apple', qty=10, price=9.99}, Item{name='apple', qty=20, price=9.99}]}//group by + mapping to Set{19.99=[banana], 29.99=[orang, watermelon], 9.99=[papaya, apple]}
- Java 8 Stream Collectors JavaDoc
- Java – How to sort a Map
- Stackoverflow – Sort a Map by values (Java)
阅读全文
0 0
- Stream Collectors groupingBy 例子
- Java 8 Stream Collectors groupingBy 示例
- Collectors.groupingBy 使用
- Java 8 Collectors: groupingBy Example
- stream 中的groupingBy 和partitioningBy
- java8特性:Collectors.groupingBy进行分组、排序等操作
- java8特性:Collectors.groupingBy进行分组、排序等操作 (二)
- Stream 中Collectors 的用法
- Java 8 Collectors 例子
- java 8 Stream Collectors使用注意
- stream 里面的 Collectors.toMap 用法
- Collectors
- Collectors
- java8 groupingby
- java lambda stream 例子
- Stream API 例子
- Spark Stream 简单例子
- Java8系列--Java Stream进阶篇(collector、collectors、colltect的关系)
- 用户注册:后台数据校验:使用xml进行校验(Struts2)
- 动态显示和隐藏状态栏
- BZOJ 3790: 神奇项链 manacher+SPFA
- 字符个数统计
- 时间复杂度和空间复杂度详解
- Stream Collectors groupingBy 例子
- vijos1037 搭建双塔-状态优化dp
- 随笔(2)备考GRE有感-阅读篇
- USACO 3.2 Magic Squares 魔板
- 洛谷 P1586 四方定理
- Druid基本配置及内置监控使用
- 结构化编程
- JavaScript二
- JDK动态代理实现原理