2个列表中所有可能的字典组合排列

时间:2012-03-12 14:15:13

标签: python dictionary permutation

假设我在python中有2个列表:

keys = [1, 2, 3, 4, 5, 6]

values = [7, 8, 9]

我希望从这两个列表中获取所有排列

类似的东西:

d = [{1:7, 2:8, 3:9}, {1:8, 2:9, 3:7}, ....... ]

我怎么能实现这个目标?

2 个答案:

答案 0 :(得分:10)

你的意思是这样吗?

>>> import itertools
>>> keys = [1, 2, 3, 4, 5, 6]
>>> values = [7, 8, 9]
>>> d = [dict(zip(kperm, values)) for kperm in itertools.permutations(keys, len(values))]
>>> len(d)
120
>>> d[:10]
[{1: 7, 2: 8, 3: 9}, {1: 7, 2: 8, 4: 9}, {1: 7, 2: 8, 5: 9}, {1: 7, 2: 8, 6: 9}, {1: 7, 2: 9, 3: 8}, {1: 7, 3: 8, 4: 9}, {1: 7, 3: 8, 5: 9}, {1: 7, 3: 8, 6: 9}, {1: 7, 2: 9, 4: 8}, {1: 7, 3: 9, 4: 8}]

答案 1 :(得分:4)

>>>import itertools
>>>list(itertools.product(*[[1, 2, 3, 4, 5, 6],[7, 8, 9]]))
>>>[(1, 7), (1, 8), (1, 9), (2, 7), (2, 8), (2, 9), (3, 7), (3, 8), (3, 9), (4, 7), (4, 8), (4, 9), (5, 7), (5, 8), (5, 9), (6, 7), (6, 8), (6, 9)]