Я пытаюсь найти 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
и пересекайтесь с другим list
и сделайте что-нибудь.