c:forEach遍历List<Map<String,Object>>
时间: 2023-10-14 08:13:51 浏览: 113
的方法你熟悉吗?可以举个例子吗?
当然可以。 c:forEach 是 JSTL 标签库中的一种标签,用于迭代集合中的数据并逐个输出。
遍历 List<Map<String,Object>> 可以这样写:
```
<c:forEach var="map" items="${list}">
<c:forEach var="entry" items="${map}">
${entry.key}: ${entry.value}<br />
</c:forEach>
</c:forEach>
```
其中,${list} 表示要遍历的 List,var="map" 表示每次迭代时将 Map 存储在名为 map 的变量中,${map} 再次使用 forEach 标签对 Map 进行遍历,var="entry" 表示每次迭代时将 Map.Entry 存储在名为 entry 的变量中。最后通过 ${entry.key} 和 ${entry.value} 获取 Map 中的键值对并输出。
需要注意的是,List<Map<String,Object>> 中的 Map 中的键值对可以是任意类型,需要根据具体情况进行类型转换。
相关问题
如何遍历 List<Map<String, Object>>
可以使用 foreach 循环遍历 List,再使用 Map 的 keySet() 方法遍历 Map 中的键值对。
示例代码:
```
List<Map<String, Object>> list = new ArrayList<>();
Map<String, Object> map1 = new HashMap<>();
map1.put("id", 1);
map1.put("name", "Alice");
list.add(map1);
Map<String, Object> map2 = new HashMap<>();
map2.put("id", 2);
map2.put("name", "Bob");
list.add(map2);
for (Map<String, Object> map : list) {
for (String key : map.keySet()) {
System.out.println(key + ": " + map.get(key));
}
}
```
输出结果:
```
id: 1
name: Alice
id: 2
name: Bob
```
Java 将List<Map<String, Object>>类型的数据分组生成新的Map<String, List<Map<String, Object>>>数据,并且不要与源数据指向同一个地址
在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`对象和列表都是新创建的,因此它们不会与源数据指向同一个地址。
阅读全文