list根据某个字段分组及遍历
时间: 2023-09-08 13:11:09 浏览: 269
List对象去重和按照某个字段排序的实现方法
可以使用Java 8的Stream API来对List进行分组和遍历。首先,你需要根据某个字段对List进行分组,可以使用Collectors.groupingBy()方法。例如,如果你有一个Student类,其中包含id、name和score属性,你可以根据name字段对List进行分组,代码如下:
```
Map<String, List<Student>> groupedList = students.stream()
.collect(Collectors.groupingBy(Student::getName));
```
这将返回一个Map,其中键是name字段的值,值是具有相同name字段值的Student对象的列表。
接下来,你可以遍历分组后的结果,可以使用Map的forEach()方法来遍历键值对。例如,你可以使用以下代码遍历分组后的结果:
```
groupedList.forEach((name, studentsList) -> {
System.out.println("Name: " + name);
System.out.println("Students: " + studentsList);
});
```
这将打印出每个分组的name值和对应的学生列表。
请注意,上述代码中的"students"和"Student"是示例代码中的类名和变量名,你需要根据你的实际情况进行相应的更改。
引用:
\[2\] Java8之前List分组: https://blog.csdn.net/y1h2l/article/details/105335072
\[3\] Java8 Stream API分组: https://blog.csdn.net/y1h2l/article/details/105335072
#### 引用[.reference_title]
- *1* *3* [Java8 Stream 对List根据一个或多个字段分组](https://blog.csdn.net/Amelia__Liu/article/details/114930388)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [list 根据某个字段分组](https://blog.csdn.net/kisscatforever/article/details/120976139)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
阅读全文