7

我有一本包含值列表和列表的字典:

dict1={'first':['hi','nice'], 'second':['night','moon']}
list1= [ 'nice','moon','hi']

我想将字典中的值与 list1 进行比较,如果每个键的值出现在列表中,则为键创建一个计数器:输出应如下所示:

   first 2
   second 1

这是我的代码:

count = 0 
for list_item in list1: 
    for dict_v in dict1.values():
      if list_item.split() == dict_v:
        count+= 1
        print(dict.keys,count)

有什么帮助吗?提前致谢

4

6 回答 6

7

我会set考虑list1O(1) 的查找时间并访问该intersection方法。然后使用 dict 理解。

>>> dict1={'first':['hi','nice'], 'second':['night','moon']}
>>> list1= [ 'nice','moon','hi']
>>> 
>>> set1 = set(list1)
>>> {k:len(set1.intersection(v)) for k, v in dict1.items()}
{'first': 2, 'second': 1}

intersection接受任何可迭代的参数,因此dict1不需要从 的值创建集合。

于 2018-10-19T16:21:08.093 回答
2

您可以使用以下 dict 理解:

{k: sum(1 for i in l if i in list1) for k, l in dict1.items()}

给定您的示例输入,这将返回:

{'first': 2, 'second': 1}
于 2018-10-19T16:16:32.557 回答
2

您可以获得列表的交集和dict1使用集合的值:

for key in dict1.keys():
    count = len(set(dict1[key]) & set(list1))
    print("{0}: {1}".format(key,count))
于 2018-10-19T16:18:24.370 回答
1

虽然简洁可以很好,但我认为最好提供一个尽可能接近 OP 原始代码的示例:

# notice conversion to set for O(1) lookup 
# instead of O(n) lookup where n is the size of the list of desired items

dict1={'first':['hi','nice'], 'second':['night','moon']}
set1= set([ 'nice','moon','hi']) 

for key, values in dict1.items():
    counter = 0
    for val in values: 
        if val in set1:
            counter += 1
    print key, counter
于 2018-10-19T16:45:28.530 回答
0

最简单和最基本的方法是:

dict1={'first':['hi','nice'], 'second':['night','moon']}
list1= [ 'nice','moon','hi']
listkeys=list(dict1.keys())
listvalues=list(dict1.values())
for i in range(0,len(listvalues)):
    ctr=0
    for j in range(0,len(listvalues[i])):
        for k in range(0,len(list1)):
            if list1[k]==listvalues[i][j]:
                ctr+=1
    print(listkeys[i],ctr)

希望能帮助到你。

于 2018-10-19T17:33:01.453 回答
0

使用collections.Counter

from collections import Counter

c = Counter(k for k in dict1 for i in list1 if i in dict1[k])
# Counter({'first': 2, 'second': 1})
于 2018-10-20T00:38:09.973 回答