溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

python中給列表排序的實(shí)例有哪些

發(fā)布時(shí)間:2020-08-14 10:30:53 來(lái)源:億速云 閱讀:142 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下python中給列表排序的實(shí)例有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

這篇文章主要介紹了Python中對(duì)列表排序?qū)嵗?需要的朋友可以參考下

很多時(shí)候,我們需要對(duì)List進(jìn)行排序,Python提供了兩個(gè)方法,對(duì)給定的List L進(jìn)行排序:

方法1.用List的成員函數(shù)sort進(jìn)行排序

方法2.用built-in函數(shù)sorted進(jìn)行排序(從2.4開(kāi)始)

這兩種方法使用起來(lái)差不多,以第一種為例進(jìn)行講解:

從Python2.4開(kāi)始,sort方法有了三個(gè)可選的參數(shù),Python Library Reference里是這樣描述的

實(shí)例1:

>>>L = [2,3,1,4]
>>>L.sort()
>>>L
>>>[1,2,3,4]

實(shí)例2:

>>>L = [2,3,1,4]
>>>L.sort(reverse=True)
>>>L
>>>[4,3,2,1]

實(shí)例3: 

>>>L = [('b',2),('a',1),('c',3),('d',4)]
>>>L.sort(cmp=lambda x,y:cmp(x[1],y[1]))
>>>L
>>>[('a', 1), ('b', 2), ('c', 3), ('d', 4)]

實(shí)例4:

>>>L = [('b',2),('a',1),('c',3),('d',4)]
>>>L.sort(key=lambda x:x[1])
>>>L
>>>[('a', 1), ('b', 2), ('c', 3), ('d', 4)]

實(shí)例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)]

實(shí)例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中對(duì)List排序的方法,其中實(shí)例3.4.5.6能起到對(duì)以L(fǎng)ist item中的某一項(xiàng)

為比較關(guān)鍵字進(jìn)行排序.

效率比較:

cmp < DSU < key

通過(guò)實(shí)驗(yàn)比較,方法3比方法6要慢,方法6比方法4要慢,方法4和方法5基本相當(dāng)

多關(guān)鍵字比較排序:

實(shí)例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)]

我們看到,此時(shí)排序過(guò)的L是僅僅按照第二個(gè)關(guān)鍵字來(lái)排的,如果我們想用第二個(gè)關(guān)鍵字

排過(guò)序后再用第一個(gè)關(guān)鍵字進(jìn)行排序呢?有兩種方法

實(shí)例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)]

實(shí)例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)]

以上是python中給列表排序的實(shí)例有哪些的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI