stream.groupingBy多层分组_微信分组名称

stream.groupingBy多层分组_微信分组名称Stream之Collectors.groupingBy(分组)的使用参考自:https://blog.csdn.net/u014231523/article/details/102535902Collectors.groupingBy配合Stream流使用,可以对集合中一个或多个属性进行分组,分组后还可以做聚合运算。首先把数据放入集合: Productprod1=newProduct(1L,1,newBigDecimal(“15.5″),”面包”,”零食”);Produ

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

Stream之Collectors.groupingBy(分组)的使用

参考自:https://blog.csdn.net/u014231523/article/details/102535902

Collectors.groupingBy配合Stream流使用,可以对集合中一个或多个属性进行分组,分组后还可以做聚合运算。

首先把数据放入集合:

	Product prod1 = new Product(1L, 1, new BigDecimal("15.5"), "面包", "零食");
    Product prod2 = new Product(2L, 2, new BigDecimal("20"), "饼干", "零食");
    Product prod3 = new Product(3L, 3, new BigDecimal("30"), "月饼", "零食");
    Product prod4 = new Product(4L, 3, new BigDecimal("10"), "青岛啤酒", "啤酒");
    Product prod5 = new Product(5L, 10, new BigDecimal("15"), "百威啤酒", "啤酒");
    Product prod6 = new Product(5L, 7, new BigDecimal("25"), "百威啤酒", "啤酒");

    List<Product> prodList = List.of(prod1, prod2, prod3, prod4, prod5, prod6);

按照类别分组

Map<String, List<Product>> map1 = prodList.stream().collect(Collectors.groupingBy(Product::getCategory));
Set<Map.Entry<String, List<Product>>> entries1 = map1.entrySet();
for (Map.Entry<String, List<Product>> entry : entries1) { 
   
    System.out.println(entry);
}

输出结果:

啤酒=[Product{ 
   id=4, num=3, price=10, name='青岛啤酒', category='啤酒'}, Product{ 
   id=5, num=10, price=15, name='百威啤酒', category='啤酒'}, Product{ 
   id=5, num=7, price=25, name='百威啤酒', category='啤酒'}]
    
零食=[Product{ 
   id=1, num=1, price=15.5, name='面包', category='零食'}, Product{ 
   id=2, num=2, price=20, name='饼干', category='零食'}, Product{ 
   id=3, num=3, price=30, name='月饼', category='零食'}]

按照多个属性拼接分组

Map<String, List<Product>> map2 = prodList.stream()
        .collect(Collectors.groupingBy(item -> item.getCategory() + "_" + item.getName()));
Set<Map.Entry<String, List<Product>>> entries2 = map2.entrySet();
for (Map.Entry<String, List<Product>> entry : entries2) { 
   
    System.out.println(entry);
}

输出结果(可以看到百威啤酒那组有两个对象):

零食_月饼=[Product{ 
   id=3, num=3, price=30, name='月饼', category='零食'}]
    
零食_面包=[Product{ 
   id=1, num=1, price=15.5, name='面包', category='零食'}]
    
啤酒_百威啤酒=[Product{ 
   id=5, num=10, price=15, name='百威啤酒', category='啤酒'}, Product{ 
   id=5, num=7, price=25, name='百威啤酒', category='啤酒'}]
    
啤酒_青岛啤酒=[Product{ 
   id=4, num=3, price=10, name='青岛啤酒', category='啤酒'}]
    
零食_饼干=[Product{ 
   id=2, num=2, price=20, name='饼干', category='零食'}]

根据不同条件分组

这里按照num数值的大小来分

Map<String, List<Product>> map3 = prodList.stream().collect(Collectors.groupingBy(item -> { 
   
    if (item.getNum() > 3) { 
   
        return "num大于3";
    } else if (item.getNum() < 3) { 
   
        return "num小于3";
    } else { 
   
        return "num等于3";
    }
}));
Set<Map.Entry<String, List<Product>>> entries3 = map3.entrySet();
for (Map.Entry<String, List<Product>> entry : entries3) { 
   
    System.out.println(entry);
}

输出结果:

num小于3=[Product{ 
   id=1, num=1, price=15.5, name='面包', category='零食'}, Product{ 
   id=2, num=2, price=20, name='饼干', category='零食'}]
    
num等于3=[Product{ 
   id=3, num=3, price=30, name='月饼', category='零食'}, Product{ 
   id=4, num=3, price=10, name='青岛啤酒', category='啤酒'}]
    
num大于3=[Product{ 
   id=5, num=10, price=15, name='百威啤酒', category='啤酒'}, Product{ 
   id=5, num=7, price=25, name='百威啤酒', category='啤酒'}]

多级分组

这里先按照类别分组,再按照num分组

Map<String, Map<String, List<Product>>> map4 = prodList.stream()
        .collect(Collectors.groupingBy(Product::getCategory, Collectors.groupingBy(item -> { 
   
            if (item.getNum() >= 8) { 
   
                return "num大于等于8";
            } else { 
   
                return "num小于8";
            }
        })));
Set<Map.Entry<String, Map<String, List<Product>>>> entries4 = map4.entrySet();
for (Map.Entry<String, Map<String, List<Product>>> entry : entries4) { 
   
    System.out.println(entry);
}

输出结果:

啤酒={ 
   num小于8=[Product{ 
   id=4, num=3, price=10, name='青岛啤酒', category='啤酒'}, Product{ 
   id=5, num=7, price=25, name='百威啤酒', category='啤酒'}], num大于等于8=[Product{ 
   id=5, num=10, price=15, name='百威啤酒', category='啤酒'}]}

零食={ 
   num小于8=[Product{ 
   id=1, num=1, price=15.5, name='面包', category='零食'}, Product{ 
   id=2, num=2, price=20, name='饼干', category='零食'}, Product{ 
   id=3, num=3, price=30, name='月饼', category='零食'}]}

分组后再聚合求总数

这里先按照类别分组,再聚合求总数

Map<String, Long> map5 = prodList.stream()
        .collect(Collectors.groupingBy(Product::getCategory, Collectors.counting()));
Set<String> strings5 = map5.keySet();
for (String s : strings5) { 
   
    System.out.println(s + "---" + "总数:" + map5.get(s));
}

输出结果:

啤酒---总数:3
零食---总数:3

分组后再做相加运算

这里先按照类别分组,再聚合运算(把num相加)

Map<String, Integer> map6 = prodList.stream()
        .collect(Collectors.groupingBy(Product::getCategory, Collectors.summingInt(Product::getNum)));
Set<String> strings6 = map6.keySet();
for (String s : strings6) { 
   
    System.out.println(s + "---" + "num相加后:" + map6.get(s));
}

输出结果:

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/171494.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • pycharm为什么有中文就运行不了_电脑右下角输入法图标不见了

    pycharm为什么有中文就运行不了_电脑右下角输入法图标不见了系统版本:Ubuntu16.04PyCharm版本:PyCharm2020.3.3(CommunityEdition)1、在pycharm安装目录bin下的pycharm.sh中,添加如下几行:ibus类型的输入法添加:exportGTK_IM_MODULE=ibusexportQT_IM_MODULE=ibusexportXMODIFIERS=@im=ibusfcitx类型的输入法添加:exportGTK_IM_MODULE=fcitxexportQT_IM_MODU

  • 【DataStructure】Some useful methods about linkedList(三)

    【DataStructure】Some useful methods about linkedList(三)

  • nginx随着passenger构造ruby on rails页

    nginx随着passenger构造ruby on rails页

  • SQL Browser_sqlitedatabase

    SQL Browser_sqlitedatabase在网上找一个SQLITE查看器这个查看器叫做:www.jb51.net/database/118822.html这个查看器可以新建SQLITE文件数据库,可以建立表索引,写SQL语句,编辑表数据不过这个查看器支持的SQLITE数据库引擎版本低了一点,先介绍一下SQLiteDatabaseBrowser2.0是怎么用的?主界面将SQLITE的db文件拖进去软…

  • LeetCode重建二叉树详解[通俗易懂]

    LeetCode重建二叉树详解[通俗易懂]LeetCode重建二叉树详解题目描述原理分析(1)大致思路(2)细节阐述代码实现(1)主函数(2)递归函数参数区间的决定递归结束的条件总结题目描述原理分析(1)大致思路下面讲解一下,前序遍历+中序遍历如何确定一个唯一的二叉树。关于二叉树的基本知识,请看二叉树的基本操作及联系。对此就不再过多重复。对于前序遍历顺序:根、左子树、右子树;对于中序的遍历顺序:左子树、根、右子树。所以通过前序遍历,我们获取前序第一个结点就是这个树的根,再在中序遍历中找到该结点的位置。在中序中,根的左边全部的是属于根左子

  • main方法的各种书写样式

    main方法的各种书写样式以下是一些正确的和一个错误的:publicstaticvoidmain(String[]args)publicstaticfinalvoidmain(String[]args)staticpublicvoidmain(String[]args)staticpublicsynchronizedvoidmain(String[]args)staticpublicabstractvoidmain(String[]args)//错误,abstract要求没

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号