Java grupo 8 corriente por con la agregación de múltiples

práctico:

Estoy tratando de mi grupo de flujo y el agregado de varios campos

es decir

private class Row {
    private String sku;
    private int colA; // sum
    private int colB; // sum
    private int colC; // avg
}

Ejemplo

  sku   colA    colB    colC
 ---------------------------
ar5sg5h  4       3       4
sd6ad6d  2       5       3
ar5sg5h  6       5       6
sd6ad6d  5       6       3
sd6ad6d  3       7       3

Esperado:

 sku    colA    colB    colC
---------------------------
ar5sg5h  10      8       5.0
sd6ad6d  10     18       3.0

Ya tengo List<Row> rows, en la que tengo intención de reducir filas con GroupBy y la agregación de suma en la cola y colB donde como promedio en colC.

¿Cómo puedo lograr esto con GroupBy + múltiples agregación utilizando Java-8 corriente ?

YCF_L:

¿Está buscando para:

List<Row> result = rows.stream()
        .collect(Collectors.groupingBy(Row::getSku))
        .values().stream()
        .map(e -> new Row(e.get(0).getSku(),
                e.stream().mapToDouble(Row::getColA).sum(),
                e.stream().mapToDouble(Row::getColB).sum(),
                e.stream().mapToDouble(Row::getColC).average().getAsDouble()))
        .collect(Collectors.toList());

Nota: el tipo int no es servicial en su caso, sugeriría que cambiarlo a doblar como el promedio no es int.

salidas

Row(sku=sd6ad6d, colA=10.0, colB=18.0, colC=3.0)
Row(sku=ar5sg5h, colA=10.0, colB=8.0, colC=5.0)

Supongo que te gusta

Origin http://10.200.1.11:23101/article/api/json?id=375010&siteId=1
Recomendado
Clasificación