私はこのような配列を持っています:
[['G', 10], ['A', 22], ['S', 1], ['P', 14], ['V', 13], ['T', 7], ['C', 0], ['I', 219]]
2番目の要素に基づいて降順で並べ替えたいと思います。理想的な出力は次のとおりです。
[['I', 219], ['A', 22], ['P', 14], ... ]
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], ...]
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
は、複数のサブ配列によるソートにも使用できます。
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
これを行う:
2番目の列に基づいて多次元配列を降順で並べ替えます。
list_name.sort(key=lambda x:x[1],reverse=True)