迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Python >

Python 中如果在另一个列表中,则从列表中删除元素

作者:迹忆客 最近更新:2023/01/25 浏览次数:

使用列表推导从列表中删除另一个列表中存在的元素,例如 result = [item for item in my_list if item not in another_list]。 列表推导将返回一个新列表,该列表不包含其他列表中的任何项目。

my_list = ['apple', 'banana', 'melon', 'kiwi']
another_list = ['apple', 'melon']

# ✅ list comprehension (best)
result = [item for item in my_list if item not in another_list]

# 👇️ ['banana', 'kiwi']
print(result)

# ------------------------

# ✅ filter()
result = list(filter(lambda item: item not in another_list, my_list))
print(result)  # 👉️ ['banana', 'kiwi']

# ------------------------

# ✅ 使用 2 个集合对象(转换为集合会删除重复项)集合对象是无序的项目集合
result = list(set(my_list) - set(another_list))
print(result)  # 👉️ ['kiwi', 'banana']

我们使用列表推导从一个列表中删除出现在另一个列表中的项目。

**列表推导**用于对每个元素执行某些操作或选择满足条件的元素子集。

在每次迭代中,我们检查当前项目是否不存在于另一个列表中并返回结果。

my_list = ['apple', 'banana', 'melon', 'kiwi']
another_list = ['apple', 'melon']

result = [item for item in my_list if item not in another_list]

# 👇️ ['banana', 'kiwi']
print(result)

in 运算符测试成员资格。 例如,如果 xl 的成员,则 x in l 的计算结果为 True,否则计算结果为 False

x not in l 返回 x in l 的否定。

列表推导不会从原始列表中删除项目,它会返回一个新列表,该列表仅包含其他列表中不存在的项目。

或者,我们可以使用 filter() 函数。

要从一个列表中删除另一个列表中存在的元素:

  1. 使用 filter() 函数过滤掉其他列表中存在的任何元素。
  2. 使用 list() 类将过滤器对象转换为列表。
  3. 新列表将不包含其他列表中存在的项目。
my_list = ['apple', 'banana', 'melon', 'kiwi']
another_list = ['apple', 'melon']

result = list(
    filter(lambda item: item not in another_list, my_list)
)
print(result)  # 👉️ ['banana', 'kiwi']

filter() 函数接受一个函数和一个可迭代对象作为参数,并从可迭代对象的元素构造一个迭代器,函数返回一个真值。

lambda 函数检查当前项目是否不存在于另一个列表中并返回结果。

过滤器对象只包含满足条件的元素。

最后一步是使用 list() 类将过滤器对象转换为列表。

另一种更高效的方法是使用两个集合对象。

要从一个列表中删除另一个列表中存在的元素:

  1. 使用 set() 类将两个列表转换为集合对象。
  2. 从第一组中减去另一组以获得差异。
  3. 使用 list() 类将差异转换为列表。
my_list = ['apple', 'banana', 'melon', 'kiwi']
another_list = ['apple', 'melon']

result = list(set(my_list) - set(another_list))
print(result)  # 👉️ ['kiwi', 'banana']

我们使用 set() 函数将两个列表转换为集合对象。

集合对象是唯一元素的无序集合。

将包含重复项的列表转换为集合时,将删除所有重复项。

另一件需要注意的事情是集合对象是无序的,因此如果我们需要保持顺序,则不应使用这种方法。

当我们从一集合中减去另一集合时,我们得到了差异。

my_list = ['apple', 'banana', 'melon', 'kiwi']
another_list = ['apple', 'melon']

# 👇️ {'kiwi', 'banana'}
print(set(my_list) - set(another_list))

我们也可以使用 set.difference() 方法来获得相同的结果。

my_list = ['apple', 'banana', 'melon', 'kiwi']
another_list = ['apple', 'melon']

result = list(set(my_list).difference(another_list))
print(result)  # 👉️ ['kiwi', 'banana']

Set 对象有一个 difference() 方法,该方法返回一个新集合,该集合中的元素不在提供的 iterable 中。

换句话说,set_1.difference(set_2) 返回一个新集合,其中包含 set_1 中不存在于 set_2 中的元素。

如果出现以下情况,我们应该只使用 set 对象方法:

  • 在将列表转换为集合时,我们可以删除任何重复值
  • 你不需要保留订单

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

Python 中的 Pandas 插入方法

发布时间:2024/04/23 浏览次数:112 分类:Python

本教程介绍了如何在 Pandas DataFrame 中使用 insert 方法在 DataFrame 中插入一列。

Pandas 重命名多个列

发布时间:2024/04/22 浏览次数:199 分类:Python

本教程演示了如何使用 Pandas 重命名数据框中的多个列。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便