尝试生成排除c中提到的组合的组合,但我不确定如何继续。
a = [1.01, 5.84, 13.86]
b = [6.42,0,18.24]
c = [(1.01,18.24), (13.86,0), (5.84,0)]
combination = [(x,y) for x in a
for y in b]
预期结果: (1.01,6.42),(1.01,0),(5.84,6.42),(5.84,18.24),(13.86,6.42),(13.86,18.24)
发布于 2018-08-18 04:28:30
您可以使用itertools.product
生成组合,然后通过比较排除它们
from itertools import product
a = [1.01, 5.84, 13.86]
b = [6.42,0,18.24]
c = [(1.01,18.24), (13.86,0), (5.84,0)]
combs = list(product(a,b))
[(1.01, 6.42),
(1.01, 0),
(1.01, 18.24),
(5.84, 6.42),
(5.84, 0),
(5.84, 18.24),
(13.86, 6.42),
(13.86, 0),
(13.86, 18.24)]
new_combs = [x for x in combs if x not in c]
[(1.01, 6.42),
(1.01, 0),
(5.84, 6.42),
(5.84, 18.24),
(13.86, 6.42),
(13.86, 18.24)]
注意:正如注释中所指出的,combs
周围的list
是用于演示的,以便您可以看到所有的组合。相反,您可能希望执行以下操作:
new_combs = [x for x in product(a,b) if x not in c]
有关元组和列表比较的更多信息,请访问此处:How does tuple comparison work in Python?
逐个位置比较元组:第一个元组的第一个项目与第二个元组的第一个项目进行比较;如果它们不相等,这是比较的结果,否则考虑第二个项目,然后是第三个项目,依此类推。
另外:
序列类型也支持比较。特别地,元组和列表通过比较相应的元素按字典顺序进行比较。这意味着要比较相等,每个元素必须比较相等,并且两个序列必须具有相同的类型和长度。
https://stackoverflow.com/questions/51902264
复制相似问题