python list 排序

巴扎黑
發布: 2016-12-07 10:22:07
原創
1369 人瀏覽過

實例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:對第二個關鍵字排序 
>>>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: 對第二個關鍵字排序 
>>>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: 對第二個關鍵字排序 
>>>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中對List排序的方法,其中實例3.4.5.6能作為以List item中的某一項 
為比較關鍵字進行排序. 
效率比較: 
cmp 透過實驗比較,方法3比方法6慢,方法6比方法4慢,方法4和方法5基本上相當 
多關鍵字比較排序: 
實例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是僅按照第二個關鍵字來排的, 

如果我們想用第二個關鍵字排過序後再用第一個關鍵字進行排序呢?有兩種方法 
實例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)] 




對於簡單的list排序,直接呼叫內建函數就可以了,但是對於dict的list排序就沒有那麼直接了,不過,還是有很簡潔的辦法的,如: 

    >>> ls1 = [{'a ' : 1, 'b' : 12}, {'a' : -1, 'b' : 22},{'a' : 12, 'b' : 32},{'a' : 6, 'b' : 42}] 
    >>> ls1.sort(key=lambda obj:obj.get('a')) 
    >>> ls1 
{    [{'a': -1, 'b': 222 a': 1, 'b': 12}, {'a': 6, 'b': 42}, {'a': 12, 'b': 32}] 
    >>> 

python中dict和list排序 
1、list排序 
   清單的排序是python內建功能,自身含有sort方法 
   如: 
   >>> s=[2,1,3,0] , 1, 2, 3] 
2、dict排序 
   字典的排序,因為每一個項目包含一個鍵值對,所以要選擇可比較的鍵或值進行排序 

    sorted(iterable[, cmp[, key [, reverse]]] 
cmp和key一般使用lambda 
如: 
>>> d={"ok":1,"no":2} 
對字典按鍵排序,用元組列表的形式返回 
>>> sorted(d.items , key=lambda d:d[0]) 
[('no', 2), ('ok', 1)] 
對字典依數值排序,以元組列表的形式傳回 
>>> sorted(d .items, key=lambda d:d[1]) 
[('ok', 1), ('no', 2)] 
3、元組列表排序 
   如 
>>> li=[(2, 'a'),(4,'b'),(1,'d')] 
>>> li.sort() 
[(1, 'd'), (2, 'a'), (4 , 'b')] 
如果字典依項的第一個元素排序的話,可以轉換成元組列表來進行 
>>> d={"ok":1,"no":2} 
>>> tt=[tuple(item) for item in d.items()] 
>>> tt.sort() 
[('no', 2), ('ok', 1)] 
4 其他人的實現,留住備忘 
下面是一個結構的例子 


>>> class test: 
        def __init__(self,a,b): 𠟠            self.b = b 
>>> test1 = test (5,25) 
>>> test2 = test(10,15) 
>>> tests = [test1,test2] 
>>> sorted(tests,cmp = lambda x,y: cmp(x.a, y.a))

>>> result = sorted(tests,key = lambda d:d.a) 
5、 

# (IMHO) the simplest approach:   items.sort () 
    return [value for key, value in items] 

# an alternative implementation, which 
# happens to run a bit faster for large 下午
#on my )o );   keys = adict. keys() 

   keys.sort() 

   return [dict[key] for key in keys] 

# a further slight speed-up on my om ): 
    keys = adict.keys() 
    keys.sort() 
    return map(adict.get, keys) 

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板