zoukankan      html  css  js  c++  java
  • stream对bean中多个项目进行分组合计的两种实现方式

    1.一个一个项目的分组合计

    list.stream().collect(

                                    Collectors..groupingBy(

                                                                          Bean::getItemA

                                                                         ,Collectors..groupingBy(

                                                                                                                Bean::getItemB,

                                                                                                                Collectors..reducing(

                                                                                                                                                 new Bean(),

                                                                                                                                                 (oldBean,newBean) -> {

                                                                                                                                                                                      Bean oldBeanA = (Bean)oldBean;

                                                                                                                                                                                      Bean newBeanA = (Bean)newBean;

                                                                                                                                                                                      if (StringUtils.isEmpty(oldBeanA .getItemA())) {

                                                                                                                                                                                                                                                                  return newBeanA;

                                                                                                                                                                                                                                                                }

                                                                                                                                                                                      oldBeanA.setItemC(oldBeanA.getItemC()+newBeanA.getItemC());

                                                                                                                                                                                      oldBeanA.setItemD(oldBeanA.getItemD()+newBeanA.getItemD());

                                                                                                                                                                                      return oldBeanA;

                                                                                                                                                                                      }

                                                                                                                                                )

                                                                                                               )

                                                                        )

                                  )

    2.利用复合Key实现多项目分组合计

    list.stream().collect(

                                   Collectors.groupingBy(

                                                                       bean -> bean.getItemA() + bean.getItemB(),

                                                                       Collectors.reducing(内容与上面的处理相同)

                                                                       )

                                  )

  • 相关阅读:
    P2519 [HAOI2011]problem a
    P1084 疫情控制
    P1941 飞扬的小鸟
    NOIP填坑计划
    P2831 愤怒的小鸟
    AGC 16 D
    P3960 列队
    Python3爬虫相关软件,库的安装
    软件理论基础—— 第一章命题逻辑系统L
    软件理论基础——导论
  • 原文地址:https://www.cnblogs.com/wzhw2015/p/12381518.html
Copyright © 2011-2022 走看看