У мене є список списків. Наприклад,
[
[0,1,'f'],
[4,2,'t'],
[9,4,'afsd']
]
Якби я хотів сортувати зовнішній список за рядковим полем внутрішніх списків, як би ви це зробили в python?
У мене є список списків. Наприклад,
[
[0,1,'f'],
[4,2,'t'],
[9,4,'afsd']
]
Якби я хотів сортувати зовнішній список за рядковим полем внутрішніх списків, як би ви це зробили в python?
Відповіді:
Це робота для 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']]
Тут також можна використовувати функцію лямбда, однак лямбда-функція у цьому простому випадку повільніше
key=lambda x:x[2].casefold(). Якщо ваш Python недостатньо новий, просто використовуйте .lower()замість.casefold()
на місці
>>> l = [[0, 1, 'f'], [4, 2, 't'], [9, 4, 'afsd']]
>>> l.sort(key=lambda x: x[2])
не на місці, використовуючи відсортовані:
>>> sorted(l, key=lambda x: x[2])
in placeта not in place?
Itemgetter дозволяє сортувати за кількома критеріями / стовпцями:
sorted_list = sorted(list_to_sort, key=itemgetter(2,0,1))
через функцію лямбда також можна реалізувати кілька критеріїв
sorted_list = sorted(list_to_sort, key=lambda x: (x[1], x[0]))
array.sort(key = lambda x:x[1])
Ви можете легко сортувати за допомогою цього фрагмента, де 1 - індекс елемента.
Подобається це:
import operator
l = [...]
sorted_list = sorted(l, key=operator.itemgetter(desired_item_index))
Я думаю, що лямбда-функція може вирішити вашу проблему.
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']]
**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]' називає 3-й елемент у списку, а не 3-й елемент у вкладеному списку? чи має бути х [2] [2]?
Сортування виконуваного тут багатовимірного масиву
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)