如何获取两个列表之间的所有映射?

Jea*_*Pat 19 python list combinatorics python-itertools

我们有两个列表,A和B:

A = ['a','b','c']
B = [1, 2]
Run Code Online (Sandbox Code Playgroud)

是否有一种pythonic方法来构建包含2 ^ n的A和B之间的所有映射集(此处为2 ^ 3 = 8)?那是:

[(a,1), (b,1), (c,1)]
[(a,1), (b,1), (c,2)]
[(a,1), (b,2), (c,1)]
[(a,1), (b,2), (c,2)]
[(a,2), (b,1), (c,1)]
[(a,2), (b,1), (c,2)]
[(a,2), (b,2), (c,1)]
[(a,2), (b,2), (c,2)]
Run Code Online (Sandbox Code Playgroud)

使用itertools.product,可以获得所有元组:

import itertools as it
P = it.product(A, B)
[p for p in P]
Run Code Online (Sandbox Code Playgroud)

这使:

Out[3]: [('a', 1), ('a', 2), ('b', 1), ('b', 2), ('c', 1), ('c', 2)]
Run Code Online (Sandbox Code Playgroud)

the*_*eye 24

你可以用itertools.product和做zip

from itertools import product
print [zip(A, item) for item in product(B, repeat=len(A))]
Run Code Online (Sandbox Code Playgroud)

产量

[[('a', 1), ('b', 1), ('c', 1)],
 [('a', 1), ('b', 1), ('c', 2)],
 [('a', 1), ('b', 2), ('c', 1)],
 [('a', 1), ('b', 2), ('c', 2)],
 [('a', 2), ('b', 1), ('c', 1)],
 [('a', 2), ('b', 1), ('c', 2)],
 [('a', 2), ('b', 2), ('c', 1)],
 [('a', 2), ('b', 2), ('c', 2)]]
Run Code Online (Sandbox Code Playgroud)

product(B, repeat=len(A)) 产生

[(1, 1, 1),
 (1, 1, 2),
 (1, 2, 1),
 (1, 2, 2),
 (2, 1, 1),
 (2, 1, 2),
 (2, 2, 1),
 (2, 2, 2)]
Run Code Online (Sandbox Code Playgroud)

然后我们从产品中挑选每个元素并将其压缩A,以获得所需的输出.


CoD*_*anX 11

import itertools as it

A = ['a','b','c']
B = [1, 2]

for i in it.product(*([B]*len(A))):
    print(list(zip(A, i)))
Run Code Online (Sandbox Code Playgroud)

输出:

[('a', 1), ('b', 1), ('c', 1)]
[('a', 1), ('b', 1), ('c', 2)]
[('a', 1), ('b', 2), ('c', 1)]
[('a', 1), ('b', 2), ('c', 2)]
[('a', 2), ('b', 1), ('c', 1)]
[('a', 2), ('b', 1), ('c', 2)]
[('a', 2), ('b', 2), ('c', 1)]
[('a', 2), ('b', 2), ('c', 2)]
Run Code Online (Sandbox Code Playgroud)

不确定它是否非常pythonic,如果你看,它是it.product(*([B]*len(A)))因为它使用多个python特定的语言功能.但它实际上太神秘了,不能成为pythonic ...... B根据A的长度重复n次并解压缩到产品功能.