我正在尝试一种简单的列表过滤方法,即删除列表中满足条件的元素。
>>> a = ["a" , "e" , "i" , "o" , "u"]
>>> for elem in a:
... a.remove(elem)在这种情况下,我不是在过滤,而是在尝试删除所有元素。但是,如果我使用print a命令,我看到的是:
>>> print a
["e" , "o"]用这种方法不可能删除数组中所有元素。Python删除元素,重新分配索引,然后递增它。因此,Python在每次迭代中都跳过一个元素。如果它在最简单的情况下不起作用,我如何正确地实现列表过滤?
>>> numbers = [100 , 102 , 103 , 105 , 107, 108, 110, 120]
>>> for elem in numbers:
... if elem % 2 == 0:
... numbers.remove(elem)
...
>>> numbers
[102, 103, 105, 107, 110]在这种情况下,更自然(在我看来)的列表过滤实现不起作用……你如何控制这种操作??
谢谢!
发布于 2015-12-18 16:22:25
只需使用内置函数filter()即可
>>> filter(lambda x: x % 2, numbers)
[103, 105, 107]https://stackoverflow.com/questions/34351235
复制相似问题