我在想办法把两个列表合并成所有可能的组合。所以,如果我从两张这样的列表开始:list1 = [1, 2]
list2 = [3, 4]
结果列表如下:[[[1,3], [2,4]], [[1,4], [2,3]]]
也就是说,它基本上生成一个列表列表,其中包含两个列表之间的所有潜在组合。
我一直在通过itertools,我很确定这是正确的答案,但我想不出一个办法让它这样做。我最接近的是:list1 = [1, 2, 3, 4]
list2 = [5, 6, 7, 8]
print list(itertools.product(list1, list2))
产生了:[(1, 5), (1, 6), (1, 7), (1, 8), (2, 5), (2, 6), (2, 7), (2, 8), (3, 5), (3, 6), (3, 7), (3, 8), (4, 5), (4, 6), (4, 7), (4, 8)]
因此它会处理每个列表中所有可能的项组合,但不会处理所有可能的结果列表。我怎么才能做到?
编辑:最终目标是能够单独处理每个列表以确定效率(我使用的实际数据更复杂)。因此,在上面的原始示例中,它的工作原理如下:list1 = [1, 2]
list2 = [3, 4]
Get first merged list: [[1,3], [2, 4]]
Do stuff with this list
Get second merged list: [[1,4], [2, 3]]
Do stuff with this list
如果我得到了上面描述的“列表列表”输出,那么我可以将其放入for循环并继续处理。其他形式的输出也可以,但它似乎是最简单的。