java8分组统计 map groupBy

按多个字段分组统计

map

 List<M> collect = ms.stream().collect(Collectors.toMap(k -> k.getG1()+"_"+k.getG2()+"_"+k.getG3(), e -> e, (o1, o2) -> {
                         	 o1.setK1(o1.getK1().add(o2.getK1()).setScale(2,BigDecimal.ROUND_HALF_UP));
            o1.setK2l(o1.getK2.add(o2.getK2).setScale(2,BigDecimal.ROUND_HALF_UP));
            return o1;
        })).values().stream().collect(Collectors.toList());

groupBy

public class StringUtil {

public static String format(String value, Object... paras) {
    return MessageFormat.format(value, paras);
}

}

 Map<String, List<M1>> m1= ms.stream().collect(
                Collectors.groupingBy(a -> StringUtil.format("{0}#{1}", a.getG1(),a.getG2())));

        List<MaterierlDl> collect1 = new ArrayList<>();
        materierlDlMap.forEach((k,v)->{
            //如果公司有多个值 需要增加合计行
            if(v.size()>=1){
                BigDecimal s= v.stream().map(o->o.getK0qmkcje()!=null?o.getK0qmkcje():BigDecimal.ZERO).reduce(BigDecimal.ZERO, BigDecimal::add);
                BigDecimal s2 = v.stream().map(o->o.getK0qmkcsl()!=null?o.getK0qmkcsl():BigDecimal.ZERO).reduce(BigDecimal.ZERO, BigDecimal::add);
                M hj = new M();

              
                hj.setK1l(stockSlReduce.setScale(0,BigDecimal.ROUND_HALF_UP));
                hj.setK2(stockReduce.setScale(0,BigDecimal.ROUND_HALF_UP));
                hj.setRadio("0");
                collect1.add(hj);
            }
        });
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值