[英]Java8 Stream List<Map<String,Object>> groupingBy and counting value
[英]Java8 Streams: How to preserve the value before map to be accessed by collect/groupingBy functions
我正在使用 Java8 Streams 遍历一个列表,并为我调用map
每个元素迭代,然后我需要聚合结果。 我的问题是,当我调用groupingBy
我还需要在调用map
之前访问原始对象。 这是一个片段:
list.stream() //
.filter(item -> item.getType() == HUMAN) //
.map(item -> manager.itemToHuman(item.getId())) //
.filter(Objects::nonNull) //
.collect(Collectors.groupingBy(Human::getAge, Collectors.summarizingLong(item.getCount())));
问题在于对Collectors.summarizingLong(item.getCount())
的调用,因为此时item
不可访问。 有没有一种优雅的方法来克服这个问题?
执行map()
流转换为Stream<Human>
,您不能在收集器中使用item
对象。
您可以将item
转换为一对Human
对象并使用SimpleEntry
进行count
然后在收集器上使用它。
list.stream()
.filter(item -> item.getType() == HUMAN)
.map(item ->
new AbstractMap.SimpleEntry<>(manager.itemToHuman(item.getId()), item.getCount()))
.filter(entry -> Objects.nonNull(entry.getKey()))
.collect(Collectors.groupingBy(entry -> entry.getKey().getAge(),
Collectors.summarizingLong(Map.Entry::getValue)));
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.