的Python:找到一个列表元素的数量在另一个列表
问题描述:
比方说,我有两个列表list1
和list2
为:的Python:找到一个列表元素的数量在另一个列表
list1 = [ 3, 4, 7 ]
list2 = [ 5, 2, 3, 5, 3, 4, 4, 9 ]
我想找到它存在于list2
的list1
的元素的个数。
预计产量为4,因为list1
中的3和4在list2
中出现两次。因此,总数是4
答
使用列表理解,并检查是否元素存在
c = len([i for i in list2 if i in list1 ])
更好地从一个@乔恩即
c = sum(el in list1 for el in list2)
输出:4
答
可以遍历first
列表和add
发生给定数字到sum
使用count
方法。
for number in list1:
s += list2.count(number);
答
您可以使用sum(...)
与发电机表达来实现这一目标:
>>> list1 = [ 3, 4, 7 ]
>>> list2 = [ 5, 2, 3, 5, 3, 4, 4, 9 ]
# v returns `True`/`False` and Python considers Boolean value as `0`/`1`
>>> sum(x in list1 for x in list2)
4
作为替代方案,你也可以使用Python的__contains__
的神奇功能检查列表中是否存在元素使用filter(..)
过滤掉列表中不满足“in”条件的元素。例如:
>>> len(list(filter(list1.__contains__, list2)))
4
# Here "filter(list(list1.__contains__, list2))" will return the
# list as: [3, 3, 4, 4]
约__contains__
有关详细信息,请阅读:What does __contains__
do, what can call __contains__
function?。
+0
没有想到使用dunder方法并不是很好的做法 - 这会只适用于Python 2 –
答
你可以在这里使用collections.Counter,所以这是一个天真而相当丑陋的实现(我的)。
list1 = [ 3, 4, 7 ]
list2 = [ 5, 2, 3, 5, 3, 4, 4, 9 ]
from collections import Counter
total = 0
c = Counter(list2)
for i in list1:
if c[i]:
total += c[i]
这并没有考虑到,如果你有在第一列表(HT乔恩)重复,和更优雅的版本,这一切都发生了什么:
counter = Counter(list2)
occurrences = sum(counter[v] for v in set(list1))
为什么要建立一个列表在这里...虽然由于列表检查效果不好,你也可以把它写成'sum(列表1中el的列表中的el)' –