我有两个列表,每个列表包含来自sql查询的行,包含2个元素(列)运算符和id 我想用两个列表映射运算符,并从两个列表中打印id(两个列表中的id对应于运算符)
在这种情况下,操作员无法成为关键。
**List 1** **Lists 2**
operator1, id1 operator4, id7
operator1, id2 operator3, id8
operator2, id3 operator2, id9
operator2, id4 operator2, id10
operator3, id5 operator1, id11
operator4, id6 operator1, id12
最终输出应该是这样的
**List3**
operator1, id1,id2,id11,id12
operator2, id3,id4,id9,id11
operator3, id5,id8
operator4, id6,id7
以何种方式实施?
答案 0 :(得分:1)
而不是List3创建一个地图作为目标源。 Map将以操作符作为键,以逗号分隔的ID作为值。
答案 1 :(得分:1)
最简单的方法是使用Map按运算符分组。实际上,您可以使用Map而不是List,但您也可以迭代map以附加键和值并将它们插回列表。您可以使用以下代码来实现所需的结果。
public static void main(String[] args) {
List<Object> list1 = new ArrayList<Object>();
list1.add("operator1, id1");
list1.add("operator1, id2");
list1.add("operator2, id3");
list1.add("operator2, id4");
list1.add("operator3, id5");
list1.add("operator4, id6");
List<Object> list2 = new ArrayList<Object>();
list2.add("operator4, id7");
list2.add("operator3, id8");
list2.add("operator2, id9");
list2.add("operator2, id10");
list2.add("operator1, id11");
list2.add("operator1, id12");
Map<String, String> map = new HashMap<String, String>();
List<Object> list3 = new ArrayList<Object>();
Iterator<Object> it1 = list1.iterator();
Iterator<Object> it2 = list2.iterator();
while (it1.hasNext() && it2.hasNext()) {
String[] line1 = ((String) it1.next()).split(",");
map.put(line1[0], map.get(line1[0]) == null ? line1[1] : map.get(line1[0]) + ", " + line1[1]);
String[] line2 = ((String) it2.next()).split(",");
map.put(line2[0], map.get(line2[0]) == null ? line2[1] : map.get(line2[0]) + ", " + line2[1]);
}
for (Map.Entry<String, String> entry : map.entrySet()) {
String item = entry.getKey() + "," + entry.getValue();
System.out.println(item);
list3.add(item);
}
}
运行上面的代码后,结果将是:
operator4, id6, id7
operator1, id1, id2, id11, id12
operator3, id5, id8
operator2, id3, id4, id9, id10
答案 2 :(得分:1)
稍微紧凑且可能有用的方法:
Map<String, List<String>> map = new HashMap<String, List<String>>();
for ( List<String> list : lists ) // List1 and List2 specifically
{
for ( String s : list )
{
if ( map.get( getOperator( s ) ) == null )
{
map.put( getOperator( s ) , new ArrayList<String>() );
}
map.get( getOperator( s ) ).add( getId( s );
}
}
map.entrySet(); // will be a more useful version of your List3
方法getOperator( String )
和getId( String )
显而易见。