2011-12-04 58 views
4

我有一个列表的庞大的群体,我想结合列表中的:它看起来有点像这样:如何在Python中组合两个列表中的每个元素?

[[1,2,3,4,5], [6,7,8,9,0], [2,5,7,9,4], [4,7,8,43,6]...] 

达到这些名单的约20在列表中。我现在想第一个列表,第二个列表相结合,看起来像这样:

[[1,6], [2,7], [3,8], [4,9], [5,0]] 

然后,我要与第一和第三,所有的方式,直到最后再做一遍。然后再次从第二个列表开始到第3,第4 ...最后一行(但不是第1个,因为这已经在第1到第2列表中完成了)。我怎样才能编写这样做的代码?

这是我到目前为止有:

xcols =列的所有列表像我展示上面

def MakeLists(xcols): 
    multilist = [] 
    for i in xcols: 
     for j in xcols[index(i):]: 
      currentlist = map(list.__add__, i, j) 
      multilist.append(currentlist) 

给我一个错误,当我运行它,虽然,可能是在地图的一部分因为我不知道如何首先将每个元素转换为列表然后映射它们。任何帮助都会很棒。谢谢!

回答

4

怎么是这样的:

>>> import itertools 
>>> foo = [[1, 2, 3], [4, 5, 6], [7, 8, 8]] 
>>> for p in itertools.permutations(foo, 2): 
...  print zip(*p) 
... 
[(1, 4), (2, 5), (3, 6)] 
[(1, 7), (2, 8), (3, 8)] 
[(4, 1), (5, 2), (6, 3)] 
[(4, 7), (5, 8), (6, 8)] 
[(7, 1), (8, 2), (8, 3)] 
[(7, 4), (8, 5), (8, 6)] 

编辑: 如果你只是想压缩与后一个列表,如人的意见正在解释:

>>> import itertools 
>>> for p in itertools.combinations(foo, 2): 
...  print zip(*p) 
... 
[(1, 4), (2, 5), (3, 6)] 
[(1, 7), (2, 8), (3, 8)] 
[(4, 7), (5, 8), (6, 8)] 
+0

这将是一个非常好的解决方案,但这不会以OP想要它工作的方式工作 - 它用第一个等压缩第二个列表(但它应该仅在第二个列表后面用“zip”等等。)。 – Tadeck

+0

我认为OP必须要求组合,而不是排列:“(但不是第一个,因为这已经完成了第1至第2列表)” –

+0

谢谢,伙计们。我想我没有正确理解或者没有引起足够的重视。我已经更新了我的答案。 – stranac

2
a=[[1,2,3,4,5],[6,7,8,9,0],[2,5,7,9,4],[4,7,8,43,6]] 

i=0 

for l in a[i:]: 
    for inner in a[i+1:]: 
     print [list(b) for b in zip(l, inner)] 
    i += 1 

打印

[[1, 6], [2, 7], [3, 8], [4, 9], [5, 0]] 
[[1, 2], [2, 5], [3, 7], [4, 9], [5, 4]] 
[[1, 4], [2, 7], [3, 8], [4, 43], [5, 6]] 
[[6, 2], [7, 5], [8, 7], [9, 9], [0, 4]] 
[[6, 4], [7, 7], [8, 8], [9, 43], [0, 6]] 
[[2, 4], [5, 7], [7, 8], [9, 43], [4, 6]] 
+0

通常,您不希望在Python中使用c样式循环。有时是必要的,但它是不刺激的。 –

1
def foo(li): 
    for element in li[1:]: 
    for pair in zip(li[0], element): 
     yield pair 

>>> from test import foo 
>>> bar = [[1, 2, 3, 5, 6], [6, 7, 8, 9, 10], [11, 12, 13, 14, 15]] 
>>> foo(bar) 
<generator object foo at 0x10592df50> 
>>> [e for e in foo(bar)] 
[(1, 6), (2, 7), (3, 8), (5, 9), (6, 10), (1, 11), (2, 12), (3, 13), (5, 14), (6, 15)] 
1

你只能如果您有偶数个列表来完成你想要的结果。这段代码将产生预期的结果。但是,可能会有更多的“pythonic”。

foo = [[1,2,3,4,5],[6,7,8,9,0],[2,5,7,9,4],[4,7,8,43,6]] 
newlist = [] 

for i in xrange(len(foo)): 
    if i % 2 == 0: 
     list1 = foo[i] 
     list2 = foo[i + 1] 
     for n in xrange(len(list1)): 
      newlist.append([list1[n],list2[n]]) 

print newlist 

结果:

[[1, 6], [2, 7], [3, 8], [4, 9], [5, 0], [2, 4], [5, 7], [7, 8], [9, 43], [4, 6]] 
1

最短的解决方案(lsts是你有一个列表的列表):

[zip(lsts[i],lsts[j]) for i in xrange(len(lsts)) for j in xrange(i,len(lsts)) if i!=j] 

这会对你说什么。尝试一下。

是你期望的吗?

相关问题