我正在尝试根据一些条件找到两个列表的intersection
,并执行一些步骤。找不到方法(在学习阶段) :)
Double totalAmount = 0.00d;
Double discount = 0.00d;
List<OrderLineEntry> orderLineEntryList = orderEntry.getOrderReleases().stream()
.flatMap(orderReleaseEntry -> orderReleaseEntry.getOrderLines().stream())
.filter(orderLineEntry -> orderLineEntry.getStatus().equals("PP") || orderLineEntry.getStatus().equals("PD"))
.collect(Collectors.toList());
for (OrderLineEntry orderLineEntry : orderLineEntryList) {
for (SplitLineEntry splitLineEntry : splitReleaseEntry.getLineEntries()) {
if (splitLineEntry.getOrderLineId().equals(orderLineEntry.getId()) && splitLineEntry.getStatusCode() != "PX") {
totalAmount += orderLineEntry.getFinalAmount();
couponDiscount += orderLineEntry.getCouponDiscount() == null ? 0.00d : orderLineEntry.getCouponDiscount();
}
}
}
如您所见,逻辑很简单
根据一些过滤器list
从order中获取所有商品,并与另一个list
相交,然后做一些事情。
发布于 2015-07-29 01:46:50
最简单的方法是:
List<T> intersect = list1.stream()
.filter(list2::contains)
.collect(Collectors.toList());
发布于 2016-07-27 07:42:24
List<T> intersect = list1.stream().filter(set1::contains).collect(Collectors.toList());
只要T
是一个String
,Integer
,Float
等,其中的equals和HashCode方法是直接的,这就可以工作。但是如果T
是一个自定义对象,我们需要实现HashCode & equals
https://stackoverflow.com/questions/31683375
复制相似问题