- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在 Streams API
中遇到了一个难以解决的问题。好吧,据我所知,它是可以解决的,但在一次调用中并不优雅。下面,采用 FeatureContentWeight
对象流,我想按 feature 和 content 分组并获得每个最大权重功能和内容。我在最后从 Map
中获取值,因为我不需要维护 Map
。问题是,我只想要包含超过 3 个项目的组。因此,我想要超过给定计数的Feature,Content 对 的每个功能和内容的最大权重。在 SQL
中,这只是一个简单的 HAVING
子句。在 Streams API
中,它看起来并不微不足道,但我现在才使用 Streams API
几天。
任何想法表示赞赏。以下是我的方法,
List<FeatureContentWeight> nearestNeighbors = neighborPostings
.stream()
.collect(
groupingBy(
p -> FeatureContent.Create(p.getFeatureId(), p.getContentId()),
collectingAndThen(maxBy(comparingDouble(FeatureContentWeight::getWeight)),Optional::get))).values();
最佳答案
正如您所注意到的,不幸的是,JDK 的 Stream
API 中没有流式 GROUP BY
操作(即使有流式 distinct()
操作)。 collect()
是一个终端操作,它将组和聚合收集到具体的 Map
中。
但是,如本 article showing SQL clauses and their equivalents in Java 8 Streams 中所述,您可以重新流式传输 Map.entrySet()
并对其执行进一步的操作。
应用于您的代码(我在这里做了一些假设):
Map<FeatureContentWeight, Double> nearestNeighbors = neighborPostings
.stream()
// GROUP BY featureId, contentId
.collect(
groupingBy(
p -> FeatureContent.Create(p.getFeatureId(), p.getContentId())
)
)
// HAVING count(*) >= 3
.entrySet()
.stream()
.filter(e -> e.getValue().size() >= 3)
// SELECT grp, MAX(weight)
.map(e -> e.getValue().stream().collect(
maxBy(comparingDouble(w -> w.getWeight))
));
关于Java 8 Streams API HAVING 子句等同于 GroupingBy?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26818307/
有没有一种方法可以简化它并直接将从 groupingBy 获得的映射转换为具有键和值作为属性的元素列表?而不是有 2 倍的转换流。 我在这里做的是获取 RiskItems,然后将它们映射到 DTO,之
我面临一个棘手的情况,我必须在具有嵌套列表的对象上使用 groupingBy。我用 map()、flatmap()、toMap() 尝试了一些东西,但无法想出一个解决方案,只是在兜圈子。非常感谢来自流
我想知道流(或收集器)中是否已经实现了将列表排序为值的功能。例如。以下代码都生成按性别分组的人员列表,并按年龄排序。第一个解决方案有一些开销排序(并且看起来有点邋遢)。第二种解决方案需要对每个人进行两
这个问题在这里已经有了答案: Java 8 is not maintaining the order while grouping (2 个答案) Stream doesn't preserve t
我有一个 List>想要一个 Map>>这将映射每个 Integer所有 sets包含 Integer . 这里明显的候选者是使用 Collectors.groupingBy但它不起作用,因为 gro
我想知道,流(或收集器)中是否已经实现了将列表排序为值的功能。例如。以下代码均生成按年龄排序的按性别分组的人员列表。第一个解决方案有一些开销排序(看起来有点邋遢)。第二种解决方案需要对每个人进行两次检
我正在尝试做的一个简化示例: 假设我有一个字符串列表,需要根据是否包含特定子字符串的条件将其分为 4 组。如果一个字符串包含 Foo 它应该属于 FOO 组,如果它包含 Bar 它应该属于 BAR 组
我想通过基于 LocalDateTime 的集合进行分组,但我只想获取小时,而不是分钟、秒... .collect(Collectors.groupingBy(cp -> getUpdateLocal
我有一个Employee类: public class Employee { public enum Sex { MALE, FEMALE } private
考虑this SO answer 我有几个问题: 它是如何运作的?是groupingBy()检查返回值是否来自classifier是 List并比较每一项?对我来说,这听起来不像是典型的 Java 函
我有一个College具有嵌套静态类的类 Dept 学院 class College { private String collegeName; private Dept dept; public D
编译器在这里给了我一个非静态方法错误,我已经知道这并不意味着它一定是问题,但我真的找不到其他任何东西,特别是因为我在不同的类中有相同的方法对于通行证来说,一切正常。 public Map> setup
我有一个Employee类: public class Employee { public enum Sex { MALE, FEMALE } private
考虑this SO answer 我有几个问题: 它是如何运作的?是groupingBy()检查返回值是否来自classifier是 List并比较每一项?对我来说,这听起来不像是典型的 Java 函
我有一个类,假设 CheeseMojo 具有以下各种字段: public class CheeseMojo { private String recipies = "Recipies";
tl/dr:Kotlin 如何使用 groupingBy 和聚合来获得(键,数字)对的序列以求和到计数映射? 我有 30gb 的 csv 文件,可以轻松阅读和解析。 File("data").walk
我有一个 Employee 的列表 public class Employee { private String name; private Integer age; private Do
我有一个类叫做 Food : public class Food { private Collection foodToFoodGroups; //getters and setter
假设我有一个国家/地区对象列表,其中包含该国家/地区使用的语言列表,如下所示: class Country { List languages; } 我想创建以下格式的 map : Map> ,
给定一个 TimeEntry 对象列表,我想将它们分组为 Day 和 Hour 对象。 其中 Day 有 Hour 对象的列表,而 Hour 有其代表的小时的 TimeEntry 对象的列表。 Day
我是一名优秀的程序员,十分优秀!