Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

counting element occurrences in nested lists

This is probably quite a straightforward question, but I can't find an answer elsewhere so I'll ask. What is the best way to find the number of times an element appears in a nested list? For example:

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

How would I find how many times 'a' is the first element of the list? Or more generally, how many times 'a' appears in my_list at all? I imagine there's a way to do this with collections.Counter, but I haven't been able to figure it out.

EDIT For my_list, I would like an output of a:3 when counting if it's the first element of the list. If the question was changed to see if b is the second element, the desired output would be b:2

like image 925
Snaaa Avatar asked Dec 05 '22 15:12

Snaaa


2 Answers

Use a nested generator expression:

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

To count the items in the first position, a different generator expression gets that item for counting:

Counter(sublist[0] for sublist in my_list)

Demo:

>>> 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})
like image 68
Martijn Pieters Avatar answered Dec 07 '22 04:12

Martijn Pieters


from collections import Counter
from itertools import chain

counts = Counter(chain.from_iterable(my_list))

or generate a new list and use count:

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

If you wanted how many times 'a' is the first, then something like:

sum(1 for el in my_list if el[0] is a) # or == a if object identity is not required
like image 36
Jon Clements Avatar answered Dec 07 '22 04:12

Jon Clements