java Map集合中存放不同的Key 且key 对应多个不同的值??
一个List集合中存放了许多节点类型的字符串,比如:在List定义的list中存放了<Node1>A1</Node><Node2>B1</Node><Node3>C1</...
一个List集合中存放了许多节点类型的字符串,
比如:在List定义的list中存放了
<Node1>A1</Node>
<Node2>B1</Node>
<Node3>C1</Node>
<Node1>A2</Node>
<Node2>B2</Node>
<Node3>C2</Node>
<Node1>A3</Node>
<Node2>B3</Node>
<Node3>C3</Node>
等等这样可以重复的字符串,
现在我要做的是提取出节点的名称(比如:Node1)和值(比如:A1),
----上面的已经作出来了,利用循环出来 重要的是下面的逻辑 我不会---
将上面循环取到的一个 节点 与 值 存放到Map集合中
Map<String,List<String>>> map = new HashMap<String,List<String>>
key是节点名称比如:Node1 key对应的List是节点对应的值 (比如:A1,A2)
但是现在的问题是:有节点名称Node1,对应的是A1.A2,A3 怎样将这些数据放入到上述类型的Map集合中。
请各位大侠帮助
若不是同一个节点,就需要创建一个List集合来存放该节点对应的值 展开
比如:在List定义的list中存放了
<Node1>A1</Node>
<Node2>B1</Node>
<Node3>C1</Node>
<Node1>A2</Node>
<Node2>B2</Node>
<Node3>C2</Node>
<Node1>A3</Node>
<Node2>B3</Node>
<Node3>C3</Node>
等等这样可以重复的字符串,
现在我要做的是提取出节点的名称(比如:Node1)和值(比如:A1),
----上面的已经作出来了,利用循环出来 重要的是下面的逻辑 我不会---
将上面循环取到的一个 节点 与 值 存放到Map集合中
Map<String,List<String>>> map = new HashMap<String,List<String>>
key是节点名称比如:Node1 key对应的List是节点对应的值 (比如:A1,A2)
但是现在的问题是:有节点名称Node1,对应的是A1.A2,A3 怎样将这些数据放入到上述类型的Map集合中。
请各位大侠帮助
若不是同一个节点,就需要创建一个List集合来存放该节点对应的值 展开
5个回答
展开全部
List<String> list = new ArrayList<String>();
list.add("node1-a1");
list.add("node2-a1");
list.add("node3-a1");
list.add("node1-a2");
list.add("node2-a2");
list.add("node3-a2");
list.add("node1-a3");
list.add("node2-a3");
list.add("node3-a3");
Map<String, List<String>> map = new HashMap<String, List<String>>();
for(String string : list){
String node = string.split("-")[0];
String value = string.split("-")[1];
if(map.containsKey(node)){
List<String> list2 = map.get(node);
list2.add(value);
map.put(node, list2);
}else{
List<String> list2 = new ArrayList<String>();
list2.add(value);
map.put(node, list2);
}
}
list.add("node1-a1");
list.add("node2-a1");
list.add("node3-a1");
list.add("node1-a2");
list.add("node2-a2");
list.add("node3-a2");
list.add("node1-a3");
list.add("node2-a3");
list.add("node3-a3");
Map<String, List<String>> map = new HashMap<String, List<String>>();
for(String string : list){
String node = string.split("-")[0];
String value = string.split("-")[1];
if(map.containsKey(node)){
List<String> list2 = map.get(node);
list2.add(value);
map.put(node, list2);
}else{
List<String> list2 = new ArrayList<String>();
list2.add(value);
map.put(node, list2);
}
}
来自:求助得到的回答
展开全部
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
public class Test {
public static void main(String[] args){
Map<String ,List<String>> map = new HashMap<String ,List<String>>();//存放类型的map
List l1 = new ArrayList();//假设这是你的list
List<String> l2 = new ArrayList<String>();//假设这是你的note节点集合
for(int i =0;i<l2.size();i++){
map.put(l2.get(i), l1);//存放键值
}
Iterator iter = map.entrySet().iterator();
while(iter.hasNext()){
Map.Entry entry = (Map.Entry)iter.next();
System.out.println(entry.getKey()+"======》"+entry.getValue());
}
}
}
大致就是这样子的。我不清楚你前面节点和值是怎么存放的。我就假设了两个值。你按照这种思路可以自己试试~~相信你可以做出来的。加油
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
public class Test {
public static void main(String[] args){
Map<String ,List<String>> map = new HashMap<String ,List<String>>();//存放类型的map
List l1 = new ArrayList();//假设这是你的list
List<String> l2 = new ArrayList<String>();//假设这是你的note节点集合
for(int i =0;i<l2.size();i++){
map.put(l2.get(i), l1);//存放键值
}
Iterator iter = map.entrySet().iterator();
while(iter.hasNext()){
Map.Entry entry = (Map.Entry)iter.next();
System.out.println(entry.getKey()+"======》"+entry.getValue());
}
}
}
大致就是这样子的。我不清楚你前面节点和值是怎么存放的。我就假设了两个值。你按照这种思路可以自己试试~~相信你可以做出来的。加油
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
很简单呀,就是循环list,把list中的每个元素取出来,获得节点名和节点值,用map.get(节点名)。判断在map中有没有这个节点,如果返回的list为空就表示没有这个结点,new List对象,把节点值放到list中,然后再map.put(节点名,list);如果返回的list不是空表示map中已经有这个节点了,将节点值放到list中,然后再map.put(节点名,list);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
思路很简单,就是获取node名,取出对应的value,根据循环,插入到不同的map中。你可以简单地把node的名字存到数组里面,然后循环得出,条件判断不同的node名,插入到不同的map中,这样的思想比较简单。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
2361004892加这个,方便交流
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询