如何解决迭代 Python 列表并根据另一个列表过滤元素
firstList = ["mike","mary","steve","jane"]
第二个列表包含我要过滤的名称。
filteredList = ["mike","mary"]
我想排除过滤列表中的所有名称,以便最终列表如下所示:
finalList = ["steve","jane"]
我从这个开始,但它没有运行:
for b in firstList:
for s in filteredList:
finalList = firstList[firstList[b != s]]
print(finalList)
想法?任何帮助将不胜感激。
解决方法
您可以使用列表推导来实现:
firstList = ["mike","mary","steve","jane"]
filteredList = ["mike","mary"]
finalList = [name for name in firstList if name not in filteredList]
# where `finalList` will hold: ['steve','jane']
在这里,您正在迭代 firstList
并检查 filteredList
中每个项目是否存在。如果不存在,请考虑将其用于您的新列表。
您也可以使用 set()
来实现:
set(firstList) - set(filteredList)
# returns: set(['steve','jane'])
# if it is must for you to obtain the "finalList" as `list`,# you can type-cast it as:
# finalList = list(set(firstList) - set(filteredList))
但是通过使用 set,您将无法保留这些名称在 firstList
中的顺序。并且它只会保存唯一的项目,即重复的项目将被删除。例如:如果您的“firstList”将包含 ["mike","mike","jane"]
,则 finalList
将只包含单个 "mike"
而在我上面提出的基于 list comprehension 的解决方案中,您会看到 "mike"
两次。
在您分享的代码中,它可以修复为:
finalList = []
for b in firstList:
if b not in filteredList: # checking the presence of "b" in "filteredList"
finalList.append(b)
# where `finalList` will contain: ['steve','jane']
,
#import numpy as np
np.setdiff1d(firstList,filteredList).tolist()
或带有 set
运算符的 -
list(set(firstList) - set(filteredList))
或 filter
list(filter(lambda x: x not in filteredList,firstList))
输出
['steve','jane']
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。