web-dev-qa-db-fra.com

Comment trier une liste de listes par un index spécifique de la liste interne?

J'ai une liste de listes. Par exemple,

[
[0,1,'f'],
[4,2,'t'],
[9,4,'afsd']
]

Si je voulais trier la liste externe par le champ string des listes internes, comment feriez-vous cela en python?

188
oldspice

C'est un travail pour itemgetter

>>> from operator import itemgetter
>>> L=[[0, 1, 'f'], [4, 2, 't'], [9, 4, 'afsd']]
>>> sorted(L, key=itemgetter(2))
[[9, 4, 'afsd'], [0, 1, 'f'], [4, 2, 't']]

Il est également possible d'utiliser une fonction lambda ici, mais la fonction lambda est plus lente dans ce cas simple.

264
John La Rooy

en place

>>> l = [[0, 1, 'f'], [4, 2, 't'], [9, 4, 'afsd']]
>>> l.sort(key=lambda x: x[2])

pas en place en utilisant trié:

>>> sorted(l, key=lambda x: x[2])
133
mouad

Itemgetter vous permet de trier selon plusieurs critères/colonnes:

sorted_list = sorted(list_to_sort, key=itemgetter(2,0,1))
61
fider

Comme ça:

import operator
l = [...]
sorted_list = sorted(l, key=operator.itemgetter(desired_item_index))
8
Jim Brissom

plusieurs critères peuvent également être mis en œuvre via la fonction lambda

sorted_list = sorted(list_to_sort, key=lambda x: (x[1], x[0]))
6
Rahul Kumar

Je pense que la fonction lambda peut résoudre votre problème.

old_list = [[0,1,'f'], [4,2,'t'],[9,4,'afsd']]

#let's assume we want to sort lists by last value ( old_list[2] )
new_list = sorted(old_list, key=lambda x: x[2])

#Resulst of new_list will be:

[[9, 4, 'afsd'], [0, 1, 'f'], [4, 2, 't']]
5
Tushar Niras
array.sort(key = lambda x:x[1])

Vous pouvez facilement trier à l'aide de cet extrait, où 1 est l'index de l'élément.

4
Abhishek Yadav

Tri d'un tableau multidimensionnel exécutez ici

arr=[[2,1],[1,2],[3,5],[4,5],[3,1],[5,2],[3,8],[1,9],[1,3]]



arr.sort(key=lambda x:x[0])
la=set([i[0] for i in Points])

for i in la:
    tempres=list()
    for j in arr:
        if j[0]==i:
            tempres.append(j[1])

    for j in sorted(tempres,reverse=True):
        print(i,j)
0
Nishan
**old_list = [[0,1,'f'], [4,2,'t'],[9,4,'afsd']]
    #let's assume we want to sort lists by last value ( old_list[2] )
    new_list = sorted(old_list, key=lambda x: x[2])**

corrigez-moi si je me trompe mais le «x [2]» n'appelle-t-il pas le 3ème élément de la liste, pas le 3ème élément de la liste imbriquée? devrait-il être x [2] [2]? 

0
EgmontDeVos

Plus facile à comprendre (Que fait réellement Lambda):

ls2=[[0,1,'f'],[4,2,'t'],[9,4,'afsd']]
def thirdItem(ls):
    #return the third item of the list
    return ls[2]
#Sort according to what the thirdItem function return 
ls2.sort(key=thirdItem)
0
Maz1978