JAVA8 stream 多个字段分组求和

本文介绍了一种使用Java Stream API结合Collector进行多字段分组求和的方法,通过具体示例展示了如何根据特定规则对数据进行分组并计算指定字段的总和。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

由于公司规定不让写SQL只能依靠JAVA代码去实现,会遇到很多分组求和的场景再结合网上的例子自己写了一个例子Map<String, Double> invQtyMap = containerInventories.stream().collect(Collectors.groupingBy(k->k.getBinId()+ "-binId_" +k.getItemId()+ "-itemId" ,Collectors.summingDouble(v->Double.valueOf(v.getInvQty().toString()))));
场景就是根据多个字段分组求一个字段的和,根据自己写的规则,在做相应的处理就能得到多字段分组求和。

### 使用 Java Stream多个字段分别求和 在处理复杂的数据集时,可能需要针对对象的不同属性执行独立的聚合操作。通过 `Collectors.summingInt`、`Collectors.summingLong` 或者 `Collectors.summingDouble` 可以方便地实现这一点。 对于包含多种数值类型的实体类来说,可以通过创建流应用相应的收集器来计算各个字段的总和: ```java import java.util.*; import java.util.stream.Collectors; class Widget { private Color color; private int weight; private double price; public enum Color {RED, BLUE} // Getters and setters omitted for brevity } public class SumExample { List<Widget> widgets = Arrays.asList( new Widget(Widget.Color.RED, 10, 29.9), new Widget(Widget.Color.BLUE, 20, 39.9), new Widget(Widget.Color.RED, 15, 49.9) ); Map<String, Object> result = widgets.stream() .collect(Collectors.toMap( k -> "total_" + (k.getColor() == Widget.Color.RED ? "red" : "blue"), v -> new AbstractMap.SimpleEntry<>("weight", v.getWeight()), (e1, e2) -> new AbstractMap.SimpleEntry<>(null, ((Integer)e1.getValue() + (Integer)e2.getValue())), () -> new LinkedHashMap<>()) ) .entrySet().stream() .flatMap(entry -> entry.getValue() instanceof Integer ? Stream.of(Map.entry(entry.getKey(), entry.getValue())) : (((AbstractMap.SimpleEntry<?, ?>)entry.getValue()).getValue() != null ? Stream.of(Map.entry(entry.getKey(), ((AbstractMap.SimpleEntry<?, ?>)entry.getValue()).getValue())) : Stream.empty())) .collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue)); System.out.println(result); } ``` 上述代码片段展示了如何基于颜色对重量进行分类汇总[^2]。然而为了简化逻辑且更清晰地表达意图,在实际开发过程中通常会采用如下方式直接对不同字段求和而不涉及复杂的映射转换: ```java // 假设有一个名为 'widgets' 的列表存储着 Widget 类型的对象实例 int totalWeightRedWidgets = widgets.stream() .filter(w -> w.getColor() == Widget.Color.RED) .mapToInt(Widget::getWeight) .sum(); double totalPriceBlueWidgets = widgets.stream() .filter(w -> w.getColor() == Widget.Color.BLUE) .mapToDouble(Widget::getPrice) .sum(); ``` 这段代码实现了按照特定条件筛选元素之后再对其指定属性做累加运算的功能。当面对更多样化的业务需求时,则可考虑引入更加灵活高效的解决方案如使用自定义收集器或是第三方库的支持。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值