Python - 获取列表的所有组合

时间:2013-06-18 19:06:08

标签: python list combinations permutation itertools

我知道我可以使用itertools.permutation来获得大小为r的所有排列。 但是,对于itertools.permutation([1,2,3,4],3),它将返回(1,2,3)以及(1,3,2)

  1. 我想过滤那些重复(即获得组合)

  2. 是否有一种简单的方法可以获得所有排列(所有长度)?

  3. 如何将itertools.permutation()结果转换为常规列表?

3 个答案:

答案 0 :(得分:21)

使用itertools.combinations和一个简单的循环来获得所有大小的组合。

combinations返回一个迭代器,因此您必须将其传递给list()以查看其内容(或使用它)。

>>> from itertools import combinations
>>> lis = [1, 2, 3, 4]
for i in xrange(1, len(lis) + 1):  #  xrange will return the values 1,2,3,4 in this loop
    print list(combinations(lis, i))
...     
[(1,), (2,), (3,), (4,)]
[(1, 2), (1, 3), (1, 4), (2, 3), (2, 4), (3, 4)]
[(1, 2, 3), (1, 2, 4), (1, 3, 4), (2, 3, 4)]
[(1,2,3,4)]

答案 1 :(得分:6)

听起来你实际上在寻找itertools.combinations()

>>> from itertools import combinations
>>> list(combinations([1, 2, 3, 4], 3))
[(1, 2, 3), (1, 2, 4), (1, 3, 4), (2, 3, 4)]

此示例还说明了如何将结果转换为常规列表,只需将其传递给内置list()函数。

要获得每个长度的组合,您可以使用如下所示的循环:

>>> data = [1, 2, 3, 4]
>>> for i in range(1, len(data)+1):
...     print list(combinations(data, i))
... 
[(1,), (2,), (3,), (4,)]
[(1, 2), (1, 3), (1, 4), (2, 3), (2, 4), (3, 4)]
[(1, 2, 3), (1, 2, 4), (1, 3, 4), (2, 3, 4)]
[(1, 2, 3, 4)]

或者要将结果作为嵌套列表获取,您可以使用列表推导:

>>> [list(combinations(data, i)) for i in range(1, len(data)+1)]
[[(1,), (2,), (3,), (4,)], [(1, 2), (1, 3), (1, 4), (2, 3), (2, 4), (3, 4)], [(1, 2, 3), (1, 2, 4), (1, 3, 4), (2, 3, 4)], [(1, 2, 3, 4)]]

对于平面列表而不是嵌套:

>>> [c for i in range(1, len(data)+1) for c in combinations(data, i)]
[(1,), (2,), (3,), (4,), (1, 2), (1, 3), (1, 4), (2, 3), (2, 4), (3, 4), (1, 2, 3), (1, 2, 4), (1, 3, 4), (2, 3, 4), (1, 2, 3, 4)]

答案 2 :(得分:4)

您需要itertools.combinations()。要获得常规列表,只需使用list()工厂函数。

>>> from itertools import combinations
>>> list(combinations([1, 2, 3, 4], 3))
[(1, 2, 3), (1, 2, 4), (1, 3, 4), (2, 3, 4)]