如何按索引从列表中删除元素?
我找到了list.remove(),但这会缓慢地按值扫描列表中的项。
如何按索引从列表中删除元素?
我找到了list.remove(),但这会缓慢地按值扫描列表中的项。
当前回答
pop对于从列表中删除和保留项目也很有用。del实际上在哪里丢弃了物品。
>>> x = [1, 2, 3, 4]
>>> p = x.pop(1)
>>> p
2
其他回答
使用del语句:
del listName[-N]
例如,如果要删除最后3项,则代码应为:
del listName[-3:]
例如,如果要删除最后8项,则代码应为:
del listName[-8:]
pop对于从列表中删除和保留项目也很有用。del实际上在哪里丢弃了物品。
>>> x = [1, 2, 3, 4]
>>> p = x.pop(1)
>>> p
2
如果要删除列表中特定位置的元素,如第2、第3和第7个元素,则不能使用
del my_list[2]
del my_list[3]
del my_list[7]
因为在删除第二个元素之后,您删除的第三个元素实际上是原始列表中的第四个元素。您可以过滤原始列表中的第2、第3和第7个元素,并获得一个新列表,如下所示:
new_list = [j for i, j in enumerate(my_list) if i not in [2, 3, 7]]
如前所述,最佳实践是del();或pop(),如果需要知道值。
另一种解决方案是仅重新堆叠所需的元素:
a = ['a', 'b', 'c', 'd']
def remove_element(list_,index_):
clipboard = []
for i in range(len(list_)):
if i is not index_:
clipboard.append(list_[i])
return clipboard
print(remove_element(a,2))
>> ['a', 'b', 'd']
eta:hmm……不会处理负指数值,会思考并更新
我想是吧
if index_<0:index_=len(list_)+index_
会修补它…但突然间这个想法似乎很脆弱。有趣的思想实验。似乎应该有一种“正确”的方法来实现append()/list理解。
思考
或者如果应删除多个索引:
print([v for i,v in enumerate(your_list) if i not in list_of_unwanted_indexes])
当然,也可以这样做:
print([v for i,v in enumerate(your_list) if i != unwanted_index])