前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >stream的分组_java快速对list分组

stream的分组_java快速对list分组

作者头像
全栈程序员站长
发布2022-11-10 17:59:34
1.4K0
发布2022-11-10 17:59:34
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

Stream流-分组操作

文章目录

Collectors.groupingBy()3个方法的使用示例

代码语言:javascript
复制
/**员工 * @author Yang * @create 2020-07-09 19:57 */
public class Employee { 

private String name;   // 姓
private String city;   // 城市
private Integer sales;  // 销售额
public Employee(String name, String city, Integer sales) { 

this.name = name;
this.city = city;
this.sales = sales;
}
public Employee(String city, Integer sales) { 

this.city = city;
this.sales = sales;
}
public Employee() { 

}
// getter(),setter() ....略
@Override
public String toString() { 

return "Employee{" +
"name='" + name + '\'' +
", city='" + city + '\'' +
", sales=" + sales +
'}';
}
}
代码语言:javascript
复制
    //-------------------生成测试数据---------------------
private List<Employee> getEmps(){ 

List<Employee> list = new ArrayList<>();
Random rd = new Random();
String[] citys = { 
"北京","上海","广州","杭州","深圳"};
String[] firstName = { 
"张","李","杨","宁","刘","王","高","葛"};
Integer[] sales = { 
100,50,30,20};
for (int i = 0; i < 10; i++) { 

String city = citys[rd.nextInt(5)];
Integer sale = sales[rd.nextInt(4)];
String fname = firstName[rd.nextInt(firstName.length)];
list.add(new Employee(fname,city,sale));
}
return list;
}

方法1– groupingBy(Function)

一个参数:一个分组器,使用提供的字段对集合元素进行分组,返回一个Map<字段,相同字段值的元素集>

代码语言:javascript
复制
    /** * groupBy方法1,groupingBy(Function) * * 要求:先按city分组,每个分组里面是一个员工集合 */
@Test
public void test5(){ 

List<Employee> emps = getEmps();
Map<String, List<Employee>> map = emps.stream().collect(Collectors.groupingBy(Employee::getCity));
map.forEach((key,val)->{ 

System.out.println("城市:"+key+" ---员工集: "+val);
});
}
/** * 城市:广州 ---员工集: [Employee{name='1', city='广州', sales=100}, Employee{name='5', city='广州', sales=20}, Employee{name='6', city='广州', sales=30}, Employee{name='8', city='广州', sales=30}] * 城市:上海 ---员工集: [Employee{name='0', city='上海', sales=30}] * 城市:杭州 ---员工集: [Employee{name='2', city='杭州', sales=50}, Employee{name='7', city='杭州', sales=30}] * 城市:北京 ---员工集: [Employee{name='3', city='北京', sales=30}, Employee{name='4', city='北京', sales=50}, Employee{name='9', city='北京', sales=30}] */

方法2– groupingBy(Function,Collector)

2个参数:一个是分组器,按提供的字段进行分组。一个收集器,下面举例了3种用途

代码语言:javascript
复制
    /** * groupBy方法2,groupingBy(Function,Collector) * * 要求:先按city分组 ,再对组里面的成员,统计总销售额 */
@Test
public void test3(){ 

List<Employee> emps = getEmps();
for (Employee emp : emps) { 

System.out.println(emp);
}
Map<String, Integer> map = emps.stream().
collect(Collectors.groupingBy(Employee::getCity, Collectors.summingInt(Employee::getSales)));
// 先按city分组 再对组里面的成员,统计总销售额
map.forEach((key,val)->{ 

System.out.println("城市:"+key+" 销售总额:"+val);
});
}
/** * Employee{name='0', city='上海', sales=50} * Employee{name='1', city='广州', sales=20} * Employee{name='2', city='广州', sales=30} * Employee{name='3', city='广州', sales=20} * Employee{name='4', city='杭州', sales=30} * Employee{name='5', city='杭州', sales=50} * Employee{name='6', city='北京', sales=50} * Employee{name='7', city='广州', sales=20} * Employee{name='8', city='杭州', sales=100} * Employee{name='9', city='广州', sales=30} * 城市:广州 销售总额:120 * 城市:上海 销售总额:50 * 城市:杭州 销售总额:180 * 城市:北京 销售总额:50 */
代码语言:javascript
复制
    /** * groupBy方法2,groupingBy(Function,Collector) * * 即:获取每个城市的姓氏集 * 先按城市分组,再对每个组里面的员工姓名放入Set,得到每个城市的姓氏集 */
@Test
public void test4(){ 

List<Employee> emps = getEmps();
Map<String, Set<String>> map = emps.stream().collect(Collectors.groupingBy(Employee::getCity, Collectors.mapping(Employee::getName, Collectors.toSet())));
map.forEach((key,val)->{ 

System.out.println(""+key+" ---人员姓名: "+val);
});
}
/** * 上海 ---人员姓名: [葛] * 广州 ---人员姓名: [张, 刘, 王] * 杭州 ---人员姓名: [杨, 刘, 葛] */
代码语言:javascript
复制
    /** * groupBy方法2,groupingBy(Function,Collector) * 要求:每个城市中销售额最大的员工 * 先按城市分组,在求分组里面销售额最大的员工 */
@Test
public void test6(){ 

List<Employee> emps = getEmps();
Map<String, Employee> map = emps.stream().collect(Collectors.groupingBy(Employee::getCity,
Collectors.collectingAndThen(Collectors.maxBy(Comparator.comparingInt(Employee::getSales)), Optional::get)));
map.forEach((key,val)->{ 

System.out.println("城市:"+key+" 销售额最大员工:"+val);
});
}
/** * Employee{name='杨', city='北京', sales=100} * Employee{name='杨', city='杭州', sales=20} * Employee{name='葛', city='深圳', sales=30} * Employee{name='张', city='上海', sales=50} * Employee{name='杨', city='广州', sales=50} * Employee{name='张', city='上海', sales=20} * Employee{name='张', city='上海', sales=50} * Employee{name='刘', city='北京', sales=50} * Employee{name='高', city='深圳', sales=100} * Employee{name='葛', city='深圳', sales=30} * 城市:广州 销售额最大员工:Employee{name='杨', city='广州', sales=50} * 城市:上海 销售额最大员工:Employee{name='张', city='上海', sales=50} * 城市:杭州 销售额最大员工:Employee{name='杨', city='杭州', sales=20} * 城市:深圳 销售额最大员工:Employee{name='高', city='深圳', sales=100} * 城市:北京 销售额最大员工:Employee{name='杨', city='北京', sales=100} */

方法3– groupingBy(Function,Supplier,Collector)

参数:一个分组器,一个最终类型的生产者,一个收集器 下面的示例:先按城市分组,然后收集每个城市的姓氏集,然后放入一个TreeMap,得到最终结果。(按城市名称排了序

代码语言:javascript
复制
   /** * 3个参数的方法:groupingBy(Function,Supplier,Collector) * 要求:要计算每个城市中人的姓氏集,并对城市名称进行排序 * 先按城市分组,在对每个城市 */
@Test
public void test7(){ 

List<Employee> emps = getEmps();
TreeMap<String, Set<String>> map = emps.stream().collect(Collectors.groupingBy(Employee::getCity, TreeMap::new, Collectors.mapping(Employee::getName, Collectors.toSet())));
map.forEach((key,val)->{ 

System.out.println("城市:"+key+" 姓氏集:"+val);
});
}
/** * 城市:上海 姓氏集:[刘] * 城市:北京 姓氏集:[宁, 李] * 城市:广州 姓氏集:[张, 高, 葛] * 城市:杭州 姓氏集:[张, 高, 葛] */

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/185601.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月5日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Stream流-分组操作
    • 文章目录
      • 方法1– groupingBy(Function)
        • 方法2– groupingBy(Function,Collector)
          • 方法3– groupingBy(Function,Supplier,Collector)
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档