我想知道在2D python列表中是否有计算元素频率的方法。对于一维列表,我们可以使用
list.count(word)但如果我有一份清单:
a = [ ['hello', 'friends', 'its', 'mrpycharm'], 
      ['mrpycharm', 'it', 'is'], 
      ['its', 'mrpycharm'] ]我能找到这个2D列表中每个单词的频率吗?
发布于 2016-10-19 19:36:52
如果我明白你想要什么,
>>> collections.Counter([x for sublist in a for x in sublist])
Counter({'mrpycharm': 3, 'its': 2, 'friends': 1, 'is': 1, 'it': 1, 'hello': 1})或,
>>> c = collections.Counter()
>>> for sublist in a:
...     c.update(sublist)
...
>>> c
Counter({'mrpycharm': 3, 'its': 2, 'friends': 1, 'is': 1, 'it': 1, 'hello': 1})发布于 2016-10-19 19:37:08
您可以使用defaultdict
from collections import defaultdict
d = defaultdict(int)
for sublist in a:
    for word in sublist:
        d[word] += 1发布于 2016-10-19 19:39:56
你已经知道list.count()了。只需获取每个sublist和sum中单词的计数即可。例如:
>>> my_word = 'its'
>>> sum(sublist.count(my_word) for sublist in a)
2如果你想知道你的list中每个单词的频率,这里有很多很好的答案。或者,如果您想在不使用任何import (使用普通dict)的情况下这样做,您可以这样做:
my_dict = {}
for sublist in a:
    for item in sublist:
        if item not in my_dict:
            my_dict[item] = 0
        my_dict[item] += 1
# Value of my_dict:
{'friends': 1, 'is': 1, 'it': 1, 'its': 2, 'mrpycharm': 3, 'hello': 1}https://stackoverflow.com/questions/40140067
复制相似问题