Как отсортировать список списков по определенному индексу внутреннего списка? - PullRequest
195 голосов
/ 14 ноября 2010

У меня есть список списков.Например,

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

Если бы я хотел отсортировать внешний список по строковому полю внутренних списков, как бы вы сделали это в python?

Ответы [ 10 ]

275 голосов
/ 14 ноября 2010

Это работа для 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']]

Здесь также можно использовать лямбда-функцию, однако в этом простом случае лямбда-функция медленнее

142 голосов
/ 14 ноября 2010

на месте

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

не на месте, используя сортировку:

>>> sorted(l, key=lambda x: x[2])
64 голосов
/ 21 марта 2013

Itemgetter позволяет сортировать по нескольким критериям / столбцам:

sorted_list = sorted(list_to_sort, key=itemgetter(2,0,1))
8 голосов
/ 20 июня 2018
array.sort(key = lambda x:x[1])

Вы можете легко отсортировать, используя этот фрагмент, где 1 - индекс элемента.

8 голосов
/ 14 ноября 2010

Как это:

import operator
l = [...]
sorted_list = sorted(l, key=operator.itemgetter(desired_item_index))
7 голосов
/ 24 марта 2017

множественные критерии также могут быть реализованы с помощью лямбда-функции

sorted_list = sorted(list_to_sort, key=lambda x: (x[1], x[0]))
6 голосов
/ 28 августа 2017

Я думаю, что лямбда-функция может решить вашу проблему.

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']]
0 голосов
/ 12 февраля 2019

Сортировка многомерного массива выполнить здесь

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 голосов
/ 09 января 2019
**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])**

поправьте меня, если я ошибаюсь, но разве 'x [2]' вызывает третий элемент в списке, а не третий элемент во вложенном списке?это должно быть х [2] [2]?

0 голосов
/ 23 ноября 2018

Более легко понять (что на самом деле делает 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)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...