在Python中, remove()将删除列表中第一个出现的value。
如何从列表中删除所有出现的值?
这就是我的想法:
>>> remove_values_from_list([1, 2, 3, 4, 2, 2, 3], 2)
[1, 3, 4, 3]
#1楼
我以牺牲可读性为代价,认为该版本稍快一些,因为它不会迫使用户重新检查列表,因此无论如何,要做的删除操作完全相同:
x = [1, 2, 3, 4, 2, 2, 3]
def remove_values_from_list(the_list, val):
for i in range(the_list.count(val)):
the_list.remove(val)
remove_values_from_list(x, 2)
print(x)
#2楼
您可以使用列表理解:
def remove_values_from_list(the_list, val):
return [value for value in the_list if value != val]
x = [1, 2, 3, 4, 2, 2, 3]
x = remove_values_from_list(x, 2)
print x
# [1, 3, 4, 3]
#3楼
功能方法:
2.x
>>> x = [1,2,3,2,2,2,3,4]
>>> filter(lambda a: a != 2, x)
[1, 3, 3, 4]
3.x
>>> x = [1,2,3,2,2,2,3,4]
>>> list(filter((2).__ne__, x))
[1, 3, 3, 4]
要么
>>> x = [1,2,3,2,2,2,3,4]
>>> list(filter(lambda a: a != 2, x))
[1, 3, 3, 4]
#4楼
如果必须修改原始列表,则可以使用切片分配,同时仍使用有效的列表理解(或生成器表达式)。
>>> x = [1, 2, 3, 4, 2, 2, 3]
>>> x[:] = (value for value in x if value != 2)
>>> x
[1, 3, 4, 3]
#5楼
要删除所有重复的事件并将其留在列表中:
test = [1, 1, 2, 3]
newlist = list(set(test))
print newlist
[1, 2, 3]
这是我用于欧拉计画的功能:
def removeOccurrences(e):
return list(set(e))
来源:oschina
链接:https://my.oschina.net/u/3797416/blog/3188504