您可以使用它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)]
注意:如评论中所述,list周围combs是演示,以便您可以看到所有组合。相反,你可能想做:new_combs = [x for x in product(a,b) if x not in c]
按位置比较元组:将第一元组的第一项与第二元组的第一项进行比较; 如果它们不相等,这是比较的结果,否则考虑第二项,然后是第三项,依此类推。
另外:
序列类型也支持比较。特别是,通过比较相应的元素,按字典顺序比较元组和列表。这意味着要比较相等,每个元素必须比较相等,并且两个序列必须是相同类型并且具有相同的长度。