Collectors.groupingBy 多字段分组求和
时间: 2023-12-06 15:37:59 浏览: 91
在Java8中,可以使用Collectors.groupingBy方法实现集合的分组,类似于Mysql的group by分组功能。同时,可以使用多个字段进行分组,并对分组后的结果进行求和操作。以下是一个示例代码:
假设有一个Student类,包含name、age和score三个属性,现在需要按照name和age两个字段进行分组,并对每个分组的score进行求和操作。
```java
import java.util.*;
import java.util.stream.Collectors;
public class Main {
public static void main(String[] args) {
List<Student> students = new ArrayList<>();
students.add(new Student("Tom", 18, 80));
students.add(new Student("Tom", 18, 90)); students.add(new Student("Tom", 20, 85));
students.add(new Student("Jerry", 18, 75));
students.add(new Student("Jerry", 20, 95));
Map<String, Map<Integer, Integer>> result = students.stream()
.collect(Collectors.groupingBy(Student::getName,
Collectors.groupingBy(Student::getAge,
Collectors.summingInt(Student::getScore))));
System.out.println(result); }
}
class Student {
private String name;
private int age;
private int score;
public Student(String name, int age, int score) {
this.name = name;
this.age = age;
this.score = score;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
public int getScore() {
return score;
}
}
```
输出结果为:
```
{Tom={18=170, 20=85}, Jerry={18=75, 20=95}}
```
可以看到,结果是一个嵌套的Map,第一层的key是name,第二层的key是age,value是score的和。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)