python una Como ordenar uma lista de listas por um índice específico da lista interna?




python percorrer lista de tras pra frente (8)

Como isso:

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

Eu tenho uma lista de listas. Por exemplo,

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

Se eu quisesse ordenar a lista externa pelo campo de string das listas internas, como você faria isso em python?


Eu acho que a função lambda pode resolver o seu problema.

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']]

Este é um trabalho para o itemgetter de 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']]

Também é possível usar uma função lambda aqui, no entanto, a função lambda é mais lenta neste caso simples


vários critérios também podem ser implementados através da função lambda

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

Mais fácil de entender (o que o Lambda está realmente fazendo):

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)

no lugar

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

não no lugar usando classificado:

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

array.sort(key = lambda x:x[1])

Você pode classificar facilmente usando esse snippet, em que 1 é o índice do elemento.


**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])**

me corrija se eu estiver errado, mas não é o 'x [2]' chamando o terceiro item na lista, não o terceiro item na lista aninhada? deveria ser x [2] [2]?





sorting