Python 列表排序方法

高洛峰
發布: 2016-11-23 13:27:45
原創
1600 人瀏覽過

python語言中的列表排序方法有三個:reverse反轉/倒序排序、sort正序排序、sorted可以取得排序後的列表。在更進階清單排序中,後兩中方法也可以加入條件參數進行排序。
reverse()方法

將清單中元素反轉排序,例如下面這樣
>>> x = [1,5,2,3,4]
>>> x.reverse()
>>> x
[4, 3, 2, 5, 1]

reverse列表反轉排序:是把原始列表中的元素順序從左到右的重新存放,而不會對列表中的參數進行排序整理。如果需要對清單中的參數進行整理,就需要用到列表的另一種排序方式sort正序排序。
sort()排序方法

此函數方法對列表內容進行正向排序,排序後的新列表會覆寫原始列表(id不變),也就是sort排序方法是直接修改原始列表list排序方法。
>>> a = [5,7,6,3,4,1,2]
>>> a.sort()
>>> a
[1, 2, 3, 4, 5, 6, 7 ]

許多python初學者,對sort()方法比較糊塗。有的時候會需要一個排序好的列表,而又想保存原有未排序列表,他們會這麼操作:
>>> a = [5,7,6,3,4,1,2]
>> > b = a.sort()
>>> print b
None

這個時候問題出現了,變數b得到的是一個空值。那麼想要得到排序好的列表,又想保留原始列表怎麼辦呢?列表sorted()方法可以幫你實作。
sorted()方法

即可以保留原列表,又能得到已經排序好的列表sorted()操作方法如下:
>>> a = [5,7,6,3,4,1,2]
>>> b = sorted(a)
>>> a
[5, 7, 6, 3, 4, 1, 2]
>>> b
[1, 2, 3, 4, 5, 6, 7 ]

sorted()方法可以用在任何資料型別的序列中,傳回的總是一個列表形式:
>>> sorted('iplaypython.com')
['.', 'a', 'c' , 'h', 'i', 'l', 'm', 'n', 'o', 'o', 'p', 'p', 't', 'y', 'y']
三者的區別

sort()是可變對象(字典、列表)的方法,無參數,無返回值,sort()會改變可變對象,因此無需返回值。 sort()方法是可變物件獨有的方法或屬性,而作為不可變物件如元組、字串是不具有這些方法的,如果呼叫將會傳回一個異常。
>>> a=[5,4,3,2,1]
>>> a.sort()
>>>
>>> a
[1, 2, 3, 4, 5]


sorted()是python的內建函數,並不是可變物件(列表、字典)的特有方法,sorted()函數需要一個參數(參數可以是列表、字典、元組、字串),無論傳遞什麼參數,都會傳回一個以列表為容器的回傳值,如果是字典將傳回鍵的列表。
>>> mystring="54321"
>>> mytuple=(5,4,3,2,1)
>>> mylist=[5,4,3,2,1]
>>> sorted(mystring )
['1', '2', '3', '4', '5']
>>> sorted(mytuple)
[1, 2, 3, 4, 5]
>>> sorted(mylist )
[1, 2, 3, 4, 5]


reverse()與sort的使用方式一樣,而reversed()與sorted()的使用方式相同
>>> mylist=[5,4,3 ,2,1]
>>> mylist.reverse()
>>> mylist
[1, 2, 3, 4, 5]
>>> mylist=[5,4,3,2,1]
> >> for i in reversed(mylist):
...   print i,
...
1 2 3 4 5


通過序列的切片也可以達到「逆轉」的效果
>>> mystring="54321 "
>>> mytuple=(5,4,3,2,1)
>>> mylist=[5,4,3,2,1]
>>> mystring[::-1]
'12345'
>>> mytuple[::-1]
(1, 2, 3, 4, 5)
>>> mylist[::-1]
[1, 2, 3, 4, 5]

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