Java 将List<Map<String, Object>>类型的数据分组生成新的Map<String, List<Map<String, Object>>>数据,并且不要与源数据指向同一个地址
时间: 2024-09-10 19:23:10 浏览: 55
在Java中,要将`List<Map<String, Object>>`类型的数据按照某个键分组并生成新的`Map<String, List<Map<String, Object>>>`类型的数据,可以通过遍历原列表并构建新的映射来实现。关键在于,分组依据的键值需要从每个`Map`中提取出来作为新映射的键,而值则是包含相同键值的所有`Map`对象的列表。下面是实现这一过程的代码示例:
```java
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class GroupListMaps {
public static Map<String, List<Map<String, Object>>> groupData(List<Map<String, Object>> dataList, String key) {
Map<String, List<Map<String, Object>>> groupedData = new HashMap<>();
for (Map<String, Object> dataMap : dataList) {
// 提取每个map中作为分组依据的键值
String keyValue = (String) dataMap.get(key);
// 检查该键值是否在groupedData中已存在
if (groupedData.containsKey(keyValue)) {
// 如果存在,则将当前map添加到对应的列表中
groupedData.get(keyValue).add(dataMap);
} else {
// 如果不存在,创建一个新列表,并添加当前map
List<Map<String, Object>> newList = new ArrayList<>();
newList.add(dataMap);
// 将新列表以键值作为键,放入groupedData中
groupedData.put(keyValue, newList);
}
}
return groupedData;
}
public static void main(String[] args) {
// 示例使用
List<Map<String, Object>> dataList = new ArrayList<>();
Map<String, Object> map1 = new HashMap<>();
map1.put("id", "1");
map1.put("name", "Apple");
Map<String, Object> map2 = new HashMap<>();
map2.put("id", "2");
map2.put("name", "Banana");
Map<String, Object> map3 = new HashMap<>();
map3.put("id", "1");
map3.put("name", "Cherry");
dataList.add(map1);
dataList.add(map2);
dataList.add(map3);
Map<String, List<Map<String, Object>>> grouped = groupData(dataList, "id");
// 输出分组后的结果
grouped.forEach((k, v) -> System.out.println(k + ": " + v));
}
}
```
上述代码通过遍历原始的`dataList`,并根据每个`Map`对象中的`id`字段值进行分组。这样,具有相同`id`的`Map`对象会被归集到同一个列表中,并以`id`值为键放入新的`Map`对象`groupedData`中。新的`Map`对象和列表都是新创建的,因此它们不会与源数据指向同一个地址。
阅读全文