Aparte de hacer comprensiones de listas de comprensión de listas invertidas, ¿hay una manera pitónica de ordenar Counter by value? Si es así, es más rápido que esto:
>>> from collections import Counter
>>> x = Counter({'a':5, 'b':3, 'c':7})
>>> sorted(x)
['a', 'b', 'c']
>>> sorted(x.items())
[('a', 5), ('b', 3), ('c', 7)]
>>> [(l,k) for k,l in sorted([(j,i) for i,j in x.items()])]
[('b', 3), ('a', 5), ('c', 7)]
>>> [(l,k) for k,l in sorted([(j,i) for i,j in x.items()], reverse=True)]
[('c', 7), ('a', 5), ('b', 3)
fuente
lamda i: -i[1]
Ordenado de manera más general, donde la
key
palabra clave define el método de clasificación, menos antes de que el tipo numérico indique descendente:fuente
key
palabra clave define el método de clasificación, menos antes de que el tipo numérico indique descendente