remove()按值删除首个匹配项且不返回元素,pop()按索引删除并返回被删元素;前者适用于知值不知位,后者适用于知位或需返回值。

remove() 是按值删除,找不到会报错
remove() 从列表中移除**第一个匹配的指定值**,不返回被删元素,只修改原列表。它不关心索引,只认值。
- 如果值不存在,抛出
ValueError: list.remove(x): x not in list - 重复值只删第一个,后续同值不受影响
- 无法控制删哪个位置的相同值,比如
[2, 1, 2].remove(2)总是删索引 0 的那个2
nums = [3, 1, 4, 1, 5] nums.remove(1) # 删除第一个 1 print(nums) # [3, 4, 1, 5]
pop() 是按索引删除,返回被删元素
pop() 默认删最后一个(pop(-1)),也可指定索引删任意位置。它一定返回被删的元素,同时改变原列表。
- 索引越界会触发
IndexError: pop index out of range - 不传参数等价于
pop(-1),适合当栈用(LIFO) - 想删中间某值又知道位置时,比
remove()更精准
fruits = ['apple', 'banana', 'cherry'] last = fruits.pop() # 'cherry' second = fruits.pop(1) # 'banana' print(fruits) # ['apple'] print(second) # 'banana'
该用谁?看你要解决什么问题
选 remove() 当你只知道“要删这个值”,不在乎它在哪;选 pop() 当你明确知道“要删第几个”,或需要拿到被删的值继续用。
- 去重时误用
remove()遍历删,可能漏删或索引错乱 —— 改用列表推导或反向遍历 - 用
pop(0)模拟队列(FIFO)性能差(O(n)),应改用collections.deque.popleft() - 批量删多个相同值?
remove()得循环调用,而pop()需先用index()查位置,注意查不到会报错
容易忽略的细节:原地修改与返回值差异
两者都直接修改原列表,但返回值完全不同:remove() 返回 None,pop() 返回被删元素。习惯链式调用的人容易在这里踩坑。
立即学习“Python免费学习笔记(深入)”;
- 写成
my_list.remove(x).upper()会报AttributeError,因为None没有upper方法 -
pop()的返回值常被用于赋值或条件判断,比如if items.pop() == 'done': ... - 误以为
remove()返回被删项,结果变量得到None,后续逻辑出错却不报错
实际删元素前,先想清楚:你手上有值还是有下标?需不需要用到被删的东西?这两个问题的答案几乎就决定了该敲哪个函数。










