删除列表中前 N 个元素的最有效方法?

新手上路,请多包涵

我需要从 Python 2.7 中的对象列表中删除前 n 个元素。有没有不使用循环的简单方法?

原文由 RedVelvet 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1.1k
2 个回答

您可以使用列表切片来归档您的目标。

删除前 5 个元素:

 n = 5
mylist = [1,2,3,4,5,6,7,8,9]
newlist = mylist[n:]
print newlist

输出:

 [6, 7, 8, 9]

或者 del 如果您只想使用一个列表:

 n = 5
mylist = [1,2,3,4,5,6,7,8,9]
del mylist[:n]
print mylist

输出:

 [6, 7, 8, 9]

原文由 Avión 发布,翻译遵循 CC BY-SA 4.0 许可协议

Python 列表不是在列表的开头进行操作,并且在此操作中非常低效。

虽然你可以写

mylist = [1, 2 ,3 ,4]
mylist.pop(0)

这是 非常 低效的。


如果您只想从列表中删除项目,您可以使用 del 执行此操作:

 del mylist[:n]

这也非常快:

 In [34]: %%timeit
help=range(10000)
while help:
    del help[:1000]
   ....:
10000 loops, best of 3: 161 µs per loop


如果您需要从列表的开头获取元素,您应该使用 Raymond Hettinger 的 collections.deque 及其 popleft() 方法。

 from collections import deque

deque(['f', 'g', 'h', 'i', 'j'])

>>> d.pop()                          # return and remove the rightmost item
'j'
>>> d.popleft()                      # return and remove the leftmost item
'f'

一个对比:

列表+弹出(0)

 In [30]: %%timeit
   ....: help=range(10000)
   ....: while help:
   ....:     help.pop(0)
   ....:
100 loops, best of 3: 17.9 ms per loop

双端队列 + popleft()

 In [33]: %%timeit
help=deque(range(10000))
while help:
    help.popleft()
   ....:
1000 loops, best of 3: 812 µs per loop

原文由 Sebastian Wozny 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题