List を並べ替えるには、Python には 2 つの方法があります
方法 1. List の組み込み関数 list.sort を使用して並べ替えます
list.sort(func=None, key=None, reverse=False)
Python の例 :
>>> list = [2,5,8,9,3] >>> list [2,5,8,9,3] >>> list.sort() >>> list [2, 3, 5, 8, 9]
方法 2. シーケンス型関数sorted(list)を使用して並べ替えます(2.4以降)
Pythonの例:
>>> list = [2,5,8,9,3] >>> list [2,5,8,9,3] >>> sorted(list) [2, 3, 5, 8, 9]
2つのメソッドの違い:
sorted(list) を返します。式として使用できるオブジェクト。元のリストは変更されず、新しいソートされたリスト オブジェクトが生成されます。
list.sort() はオブジェクトを返さず、元のリストを変更します。
その他の並べ替えの例:
例 1: 順方向並べ替え
>>>L = [2,3,1,4] >>>L.sort() >>>L >>>[1,2,3,4]
例 2: 逆並べ替え
>>>L = [2,3,1,4] >>>L.sort(reverse=True) >>>L >>>[4,3,2,1]
例 3: 2 番目のキーワードの並べ替え
>>>L = [('b',6),('a',1),('c',3),('d',4)] >>>L.sort(lambda x,y:cmp(x[1],y[1])) >>>L >>>[('a', 1), ('c', 3), ('d', 4), ('b', 6)]
例 4: 2 番目のキーワードを並べ替える
>>>L = [('b',6),('a',1),('c',3),('d',4)] >>>L.sort(key=lambda x:x[1]) >>>L >>>[('a', 1), ('c', 3), ('d', 4), ('b', 6)]
例 5: 2 番目のキーワードを並べ替える
>>>L = [('b',2),('a',1),('c',3),('d',4)] >>>import operator >>>L.sort(key=operator.itemgetter(1)) >>>L >>>[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
例 6: (DSU メソッド: Decorate-Sort-Undercorate)
>>>L = [('b',2),('a',1),('c',3),('d',4)] >>>A = [(x[1],i,x) for i,x in enumerate(L)] #i can confirm the stable sort >>>A.sort() >>>L = [s[2] for s in A] >>>L >>>[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
上記6つのメソッドを提供します例 3.4.5.6 はリスト項目内の特定の項目
を比較キーとしてソートするために使用できます。 効率比較:
cmp < DSU < key
実験的な比較により、方法 3 は次のようになります。メソッド 6 より遅い、メソッド 6 はメソッド 4 より遅い、メソッド 4 とメソッド 5 は基本的に同等です < DSU < key
複数のキーワード比較ソート:
例 7:
>>>L = [('d',2),('a',4),('b',3),('c',2)] >>> L.sort(key=lambda x:x[1]) >>> L >>>[('d', 2), ('c', 2), ('b', 3), ('a', 4)]
この時点でソートされた L は2 番目のキーワードのみで並べ替えます
2 番目のキーワードを使用して並べ替える場合は、2 つの方法があります
例 8:
>>> L = [('d',2),('a',4),('b',3),('c',2)] >>> L.sort(key=lambda x:(x[1],x[0])) >>> L >>>[('c', 2), ('d', 2), ('b', 3), ('a', 4)]
例 9:
>>> L = [('d',2),('a',4),('b',3),('c',2)] >>> L.sort(key=operator.itemgetter(1,0)) >>> L >>>[('c', 2), ('d', 2), ('b', 3), ('a', 4)]