ColumnFamily column = tokens.getColumnFamilies().stream()
.filter(family -> family.getName().equals("this_family"))
.findAny()
.get();
Map<String, String> tokenized = column.getColumns().stream()
.collect(Collectors.toMap(
Column::getQualifier,
Column::getValue
));
有没有办法把这两条流合并成一条?我使用第一个流在嵌套列表中进行过滤和查找,并使用第二个流根据流的结果创建地图。我想知道是否有一种方法可以用一条流来实现这一点。
像这样的
Map<String, String> tokenized = tokens.getColumnFamilies().stream()
.filter(family -> family.getName().equals("this_family"))
.collect(Collectors.toMap(
//
));
使用可选的#map()
并组合
Map<String, String> tokenized = tokens.getColumnFamilies().stream()
.filter(family -> family.getName().equals("this_family"))
.findAny()
.map(cf -> cf.getColumns().stream()).get()
.collect(Collectors.toMap(Column::getQualifier, Column::getValue));
您可以使用flatMap
获取嵌套的Stream
并展平结构:
Map<String, String> tokenized = tokens.getColumnFamilies().stream()
.filter(family -> family.getName().equals("this_family"))
.limit(1) // equivalent of findAny
.flatMap(cf -> cf.getColumns().stream())
.collect(Collectors.toMap(
Column::getQualifier,
Column::getValue
));
我有一个名为的类,用它描述活动及其开始时间和结束时间。这些属性是、、。我必须使用流对这些活动进行分组和过滤,这些活动的总持续时间超过10小时。我成功地计算了持续时间的总和,并根据活动将它们分组:
我试图收集流,丢弃很少使用的项目,如本例所示: 我有一种感觉,可以做得简单得多 - 我是对的吗?
假设我有一张房间清单 每个房间都有一份人员名单。 使用java8 streams,我想迭代房间列表,获取所有人员,在每个节点上执行一些方法(doSomething()),并获取所有过滤对象的列表。 这是使用java 8的最佳实践吗?
将此流收集到列表中 正如我所看到的,infinity循环有一些问题,所以peek()打印范围内的数字(12,99),这是可以的,但之后它再次打印范围内的数字(11,98),等等,你能解释一下我在哪里犯了错误吗?
我有一个对象的集合,每个对象都有一个元素的集合,例如: 如何使用Java 8函数式编程来过滤和收集类型等于“a”的集合? 我尝试了以下方法: 但我得到以下错误: 变量'filteredChildren'初始值设定项'parents。stream()。forEach(p- 如何按类型筛选嵌套集合并收集它们?
我从事elasticsearch,我尝试混合两个工作查询。第一个是“and filter”,第二个是“bool filter”,但我失败了。 我的查询是从用户交互界面动态生成的。 “和过滤器”: 我需要“和过滤器”来查询数据,例如,字段必须等于“非洲”或“亚洲”或为空。这是一个工作查询的示例: 此查询工作正常,结果如下: 现在我需要用字段“D\u TYPESTATUS”来限制结果数据,该字段必须与