我有嵌套的列表,并且我试图使用java流和收集器进行分组和求和以获得所需的结果。因此,我无法循环多个SubAccounts
。我必须使用for循环或其他某种逻辑。我想使用流API实现。有没有可能
Map<Long, BigDecimal> assetQuanMap = subAccounts.getAssets.parallelStream().collect(Collectors.groupingBy(Asset::getAssetId, Collectors.reducing(BigDecimal.ZERO, Asset::getQuantity, BigDecimal::add)));
我有下面的类或表示形式:
Account
SubAccount1
Assets
1 - 20
2 - 30
3 - 40
SubAccount2
Assets
1 - 10
2 - 5
3 - 3
SubAccount3
1 - 3
2 - 3
3 - 4
Accounts类如下:
Public class Account{
List<SubAccounts> list;
}
Public Class SubAccounts {
List<Assets> list;
}
Public class Assets{
Long assetId;
BigDecimal quantity ;
}
我试图在Map中获得如下结果。基本上,对于每个子帐户,我都需要在类似于以下的帐户级别对资产进行分组
1 - 33
2 - 38
3 - 47
答案 0 :(得分:6)
您必须使用两个flatMap
,以便可以按assetId
分组
Map<String, BigDecimal> collect = accounts.stream()
.flatMap(account -> account.getList().stream())
.flatMap(subAccount -> subAccount.getList().stream())
.collect(Collectors.groupingBy(Assets::getAssetId,
Collectors.reducing(
BigDecimal.ZERO,
Assets::getQuantity,
BigDecimal::add)
));
代码中的 assetId
是一个字符串,因此map的键应该是一个字符串,或者您必须对其进行转换,或者在您的类中对其进行更改,例如:
Map<Long, BigDecimal> collect = accounts.stream()
.flatMap(account -> account.getList().stream())
.flatMap(subAccount -> subAccount.getList().stream())
.collect(Collectors.groupingBy(asset -> Long.valueOf(asset.getAssetId()),
Collectors.reducing(
BigDecimal.ZERO,
Assets::getQuantity,
BigDecimal::add
)
));
注释
list
,请使用另一个有效的名称; assetId
作为属性名称,而只需使用id
; assetList
的名称中使用List,而在最后使用s
,例如assets
或accounts
。