我有一个映射的字符串,AttributeValue的列表,并想使用summingDouble
,以便分组的关键字,并找到它们的总和分别为每个关键字。
例如,
List<Map<String, AttributeValue>> ls = new ArrayList<Map<String, AttributeValue>>();
Map<String,AttributeValue> map = new HashMap<String,AttributeValue>();
map.put("key1", new AttributeValue().withN("1000"));
map.put("key2", new AttributeValue().withN("1000"));
ls.add(map);
Map<String,AttributeValue> map1 = new HashMap<String,AttributeValue>();
map1.put("key3", new AttributeValue().withN("1000"));
map1.put("key1", new AttributeValue().withN("2000"));
ls.add(map1);
这应该会返回
result = {key1: 3000, key2: 1000, key3: 1000}
其中key1是key1的值的总和。
像下面这样尝试过,但本例中的getValue是一个AttributeValue,所以它不起作用。
Map<String, Double> result = ls.stream().flatMap(m -> m.entrySet().stream()).collect(groupingBy(Map.Entry::getKey, summingDouble(Map.Entry::getValue)));
发布于 2018-10-16 02:31:53
看起来你的groupingBy应该是这样的:
groupingBy(
Map.Entry::getKey,
summingDouble(e -> Double.valueOf(e.getValue().getN())))
https://stackoverflow.com/questions/52822642
复制相似问题