web-dev-qa-db-fra.com

Python Trier le tableau multidimensionnel basé sur le 2e élément du sous-tableau

J'ai un tableau comme celui-ci:

[['G', 10], ['A', 22], ['S', 1], ['P', 14], ['V', 13], ['T', 7], ['C', 0], ['I', 219]]

Je voudrais le trier en fonction du 2e élément dans l'ordre décroissant. Un résultat idéal serait:

[['I', 219], ['A', 22], ['P', 14], ... ]
30
Federico Capello

list.sort, sorted accepte le paramètre facultatif key. La fonction key est utilisée pour générer la clé de comparaison.

>>> sorted(lst, key=lambda x: x[1], reverse=True)
[['I', 219], ['A', 22], ['P', 14], ['V', 13], ['G', 10], ...]

>>> sorted(lst, key=lambda x: -x[1])
[['I', 219], ['A', 22], ['P', 14], ['V', 13], ['G', 10], ...]

>>> import operator
>>> sorted(lst, key=operator.itemgetter(1), reverse=True)
[['I', 219], ['A', 22], ['P', 14], ['V', 13], ['G', 10], ...]
51
falsetru

Utilisez itemgetter

from operator import itemgetter
a = [[1, 3, 5], [2, 511, 7], [17, 233, 1]]
a = sorted(a, key=itemgetter(1))

Sortie: [[1, 3, 5], [17, 233, 1], [2, 511, 7]]

itemgetter peut également être utilisé pour trier par plusieurs sous-réseaux.

11
Nikhil Kollanoor
x= [[8, 9, 7],
    [1, 2, 3],
    [5, 4, 3],
    [4, 5, 6]]
x.sort(cmp=lambda x,y: cmp(x[0],y[0]))
print x
0
Manik

Faites ceci:

Triez le tableau multidimensionnel par ordre décroissant sur la base de la 2e colonne:

list_name.sort(key=lambda x:x[1],reverse=True)
0
Nidhi Alipuria