Python Сортировка многомерного массива на основе 2-го элемента Subarray У меня есть такой массив: [['G', 10], ['A', 22], ['S', 1], ['P', 14], ['V', 13], ['T', 7], ['C', 0], ['I', 219]] Я хотел бы отсортировать его на основе второго элемента в порядке убывания. Идеальный выход: [['I', 219], ['A', 22], ['P', 14], ... ] Ответ 1 list.sort, sorted принять необязательный параметр key. Функция key используется для генерации ключа сравнения. >>> 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], ...] Ответ 2 Используйте itemgetter from operator import itemgetter a = [[1, 3, 5], [2, 511, 7], [17, 233, 1]] a = sorted(a, key=itemgetter(1)) Вывод: [[1, 3, 5], [17, 233, 1], [2, 511, 7]] itemgetter также можно использовать для сортировки по нескольким подмассивам. Ответ 3 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 Ответ 4 Сделайте это: Сортируйте многомерный массив в порядке убывания на основе 2-го столбца: list_name.sort(key=lambda x:x[1],reverse=True)
Ответ 1 list.sort, sorted принять необязательный параметр key. Функция key используется для генерации ключа сравнения. >>> 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], ...]
Ответ 2 Используйте itemgetter from operator import itemgetter a = [[1, 3, 5], [2, 511, 7], [17, 233, 1]] a = sorted(a, key=itemgetter(1)) Вывод: [[1, 3, 5], [17, 233, 1], [2, 511, 7]] itemgetter также можно использовать для сортировки по нескольким подмассивам.
Ответ 3 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
Ответ 4 Сделайте это: Сортируйте многомерный массив в порядке убывания на основе 2-го столбца: list_name.sort(key=lambda x:x[1],reverse=True)