4

这可能是一个非常简单的问题,但我在其他地方找不到答案,所以我会问。查找元素在嵌套列表中出现的次数的最佳方法是什么?例如:

my_list=[[a,b,c,d],[a,b,z,d],[a,c,f,e],[d,w,f,a]]

我如何找到“a”是列表的第一个元素的次数?或者更一般地说,“a”在 my_list 中出现了多少次?我想有一种方法可以用 collections.Counter 做到这一点,但我一直无法弄清楚。

编辑a:3对于 my_list,如果它是列表的第一个元素 ,我想要一个输出。如果更改问题以查看是否b是第二个元素,则所需的输出将是b:2

4

3 回答 3

12

使用嵌套生成器表达式:

Counter(x for sublist in my_list for x in sublist)

要计算第一个位置的项目,不同的生成器表达式会获取该项目进行计数:

Counter(sublist[0] for sublist in my_list)

演示:

>>> from collections import Counter
>>> my_list=[['a','b','c','d'],['a','b','z','d'],['a','c','f','e'],['d','w','f','a']]
>>> Counter(x for sublist in my_list for x in sublist)
Counter({'a': 4, 'd': 3, 'c': 2, 'b': 2, 'f': 2, 'e': 1, 'w': 1, 'z': 1})
>>> Counter(sublist[0] for sublist in my_list)
Counter({'a': 3, 'd': 1})
于 2012-08-06T13:40:36.087 回答
3
from collections import Counter
from itertools import chain

counts = Counter(chain.from_iterable(my_list))

或生成一个新列表并使用计数:

new_list = list(chain.from_iterable(my_list))
print new_list.count(whatever)

如果你想要多少次 'a' 是第一个,那么就像:

sum(1 for el in my_list if el[0] is a) # or == a if object identity is not required
于 2012-08-06T13:42:38.160 回答
1
>>> from collections import defaultdict, Counter
>>> my_list = [['a', 'b', 'c', 'd'], ['a', 'b', 'z', 'd'], ['a', 'c', 'f', 'e'], ['d', 'w', 'f', 'a']]
>>> pos_count = defaultdict(Counter)
>>> for sublist in my_list:
        for i, c in enumerate(sublist):
            pos_count[c][i] += 1


>>> pos_count['a'][0]
3
>>> pos_count['b'][1]
2
于 2012-08-06T13:53:49.210 回答