如何解决从两个列表中查找不同的组合
给出两个任意长度的列表,我想找到两个列表之间的所有可能组合,然后在新列表中添加组合的字典对。
例如,两个列表是:
List1
-['A','B']
List2
-[1,2]
结果列表应具有以下值:
[{'A':1,'B':1},{'A':1,'B':2},{'A':2,'B':2}]
我发现的所有解决方案都只是给出了可能的组合。因此,假设我有一个长度为3和2的列表。可能的组合只有6个值。但是,根据我的要求,将有8个值。
我使用的代码:
first_list = ['A','B','C']
second_list = [1,2]
combinations = [(a,b) for a in first_list for b in second_list]
其输出为:
[('A',1),('A',2),('B',('C',2)]
我想要的输出是:
[{'A':1,'B':1,'C':1},'C':2},'B':2,'C':2}]
解决方法
您可以使用itertools.product
创建部分组合:
from itertools import product
first_list = ['A','B','C']
second_list = [1,2]
out = product(second_list,repeat=len(first_list))
combinations = [{f:s for (f,s) in zip(first_list,c)} for c in out]
print(combinations)
根据需要输出。
,您应该查找here
您可以使用
list1 = ["a","b","c"]
list2 = [1,2]
all_combinations = []
list1_permutations = itertools.permutations(list1,len(list2))
Get all permutations of `list1` with length 2
for each_permutation in list1_permutations:
zipped = zip(each_permutation,list2)
all_combinations.append(list(zipped))
print(all_combinations)
输出
[[('a',1),('b',2)],[('a',('c',[('b',('a',[('c',2)]]
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。