对象List根据某个字段分组处理成Map<String, List<String>>
时间: 2023-10-29 15:12:09 浏览: 110
假设你有一个对象列表 `List<MyObject>`,其中 `MyObject` 有一个字段 `groupField`,你想要将所有对象根据 `groupField` 分组,并将它们存储在一个 `Map<String, List<MyObject>>` 中,其中键是 `groupField` 的值,值是 `groupField` 相同的 `MyObject` 列表。
你可以使用 Java 8 中的流和 `Collectors.groupingBy()` 方法来完成这个任务。以下是示例代码:
```java
Map<String, List<MyObject>> map = myList.stream()
.collect(Collectors.groupingBy(MyObject::getGroupField));
```
这将对 `myList` 中的每个 `MyObject` 对象按照 `groupField` 字段进行分组,并返回一个 `Map<String, List<MyObject>>`,其中键是 `groupField` 的值,值是 `groupField` 相同的 `MyObject` 列表。
请注意,这需要 `MyObject` 类中有一个名为 `getGroupField()` 的方法来获取 `groupField` 字段的值。如果你使用的是不同的对象类型,请相应地更改方法引用。
相关问题
对象List根据某个字段分组处理成Map<String, List>
可以使用Java 8的Stream API和Collectors.groupingBy()方法来实现。
假设有一个对象类Person,包含属性name和age:
```java
public class Person {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
```
现在有一个Person的List,需要根据age字段进行分组,处理成Map<String, List<Person>>,其中String表示age,List<Person>表示该age下的Person列表。
```java
List<Person> personList = new ArrayList<>();
personList.add(new Person("Tom", 20));
personList.add(new Person("Jerry", 18));
personList.add(new Person("Mike", 20));
personList.add(new Person("John", 18));
personList.add(new Person("Amy", 25));
personList.add(new Person("Lucy", 25));
Map<String, List<Person>> result = personList.stream()
.collect(Collectors.groupingBy(Person::getAge, Collectors.toList()));
System.out.println(result);
```
输出结果为:
```
{18=[Person{name='Jerry', age=18}, Person{name='John', age=18}], 20=[Person{name='Tom', age=20}, Person{name='Mike', age=20}], 25=[Person{name='Amy', age=25}, Person{name='Lucy', age=25}]}
```
可以看到,输出的结果已经按照age分组,每一组的值为对应的Person列表。
List<String> getOption(Map<String, Object> params); Map<String, Object> getFollowByOption(Map<String, Object> params); void sh(Map<String, Object> params); int remindCount(Map<String, Object> params); Map<String, Object> selectCal(Map<String, Object> params); List<Map<String, Object>> selectGroup(Map<String, Object> params); List<Map<String, Object>> selectValue(Map<String, Object> params);
这段代码是一个 MyBatis 的 Mapper 接口,提供了多个方法,用于从数据库中查询数据或执行操作。具体方法如下:
- getOption:返回一个字符串列表,用于前端下拉框等组件的选项。
- getFollowByOption:返回一个 Map 对象,用于根据选项查询关注的数据。
- sh:执行审核操作,没有返回值。
- remindCount:返回一个整数值,用于提醒数量的统计。
- selectCal:返回一个 Map 对象,用于查询某个统计数据。
- selectGroup:返回一个 Map 对象列表,用于按照分组查询数据。
- selectValue:返回一个 Map 对象列表,用于查询某个字段的值。
阅读全文