我有下一个
列表testList = []
testList.append([0,-10])
testList.append([-12,122])
testList.append([13,172])
testList.append([17,296])
testList.append([-10,80])
testList.append([-16,230])
testList.append([-18, 296])
testList.append([-2, -8])
testList.append([-5,10])
testList.append([2,-4])
和另一个包含前一个列表中元素的列表:
m1 = []
m1.append([0, -10])
m1.append([13, 172])
然后我尝试使用下一个语句从列表testList
获取一个子数组:
[element for i, element in enumerate(testList) if i not in m1]
但我得到与testList
相同的列表。
我怎样才能做到这一点?
答案 0 :(得分:8)
问题在于您使用枚举。我只是一个整数,因此永远不会在列表中只有列表。试试这个:
[element for element in testList if element not in m1]
答案 1 :(得分:5)
如果您不关心列表中的订单,可以改为使用sets:
# result will be a set, not a list
not_in_testlist = set(testlist) - set(m1)
如果您希望结果再次成为列表:
# result will be a list with a new order
not_in_m1 = list(set(testlist) - set(m1))
请注意,使用集合将失去原始列表的顺序,因为集合是无序类型(它们在引擎盖下使用散列)。
如果您需要保留订单,那么Andrew Allaire的回答是正确的:
# result is a list, order is preserved
not_in_testlist = [e for e in testlist if e not in m1]
答案 2 :(得分:2)
试试这个:
def clean_list(my_list, exclusion_list):
new_list = []
for i in my_list:
if i in exclusion_list:
continue
else:
new_list.append(i)
return new_list