summingDouble на потоках Java AttributeValue - PullRequest
0 голосов
/ 15 октября 2018

У меня есть список карт String, 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)));

1 Ответ

0 голосов
/ 15 октября 2018

Похоже, ваша группировка должна быть такой:

groupingBy(
    Map.Entry::getKey, 
    summingDouble(e -> Double.valueOf(e.getValue().getN())))
...