溫馨提示×

溫馨提示×

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

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

python中sort()排序的方法

發(fā)布時間:2020-09-01 10:57:52 來源:億速云 閱讀:405 作者:小新 欄目:編程語言

這篇文章主要介紹了python中sort()排序的方法,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

python中的sort()函數(shù)只能應(yīng)用在列表list上,而sorted可以對所有可迭代的對象進行排序的操作

sort方法會在原list上直接進行排序,不會創(chuàng)建新的list。而sorted方法不會對原來的數(shù)據(jù)做任何改動,排序后的結(jié)果是新生成的。如果我們不需要原來的數(shù)據(jù)而且數(shù)據(jù)是list類型,可以用sort方法,能夠節(jié)省空間。否則要用sorted方法。

sort

在python2中,sort方法可以有3個參數(shù):key、cmp和reverse。但在python3中取消了cmp這個參數(shù),只有key和reverse兩個可選參數(shù)。參數(shù)reverse指定排序是正序還是倒序,默認是正序FALSE,不在多說。參數(shù)key指定了只含一個參數(shù)的方法,這個方法用來從列表的每個元素中提取比較鍵??梢钥纯聪旅鎺讉€例子:

1.通過元素長度排序

strlist = ["bbb","ccc","bac","ab","ba"]
strlist.sort(key=len)
print(strlist)

打印結(jié)果如下:

['ab', 'ba', 'bbb', 'ccc', 'bac']

2.通過元素的字符順序

strlist = ["bbb","BBB","bAc","ab","bac"]
strlist.sort()print(strlist)
strlist.sort(key=str.lower)print(strlist)

打印結(jié)果如下:

['BBB', 'ab', 'bAc', 'bac', 'bbb']
['ab', 'bAc', 'bac', 'BBB', 'bbb']

3.更復雜一點的排序:list里的元素是一個字典,通過字典的某個屬性值排序。下面是通過學生的年齡排序

student = [{"name": "小C", "age": 12, "score": 90},
           {"name": "小D", "age": 13, "score": 84},
           {"name": "小A", "age": 14, "score": 85},
           {"name": "小E", "age": 15, "score": 89},
           {"name": "小F", "age": 12, "score": 88}]
student.sort(key=lambda a: a["age"])
print(student)

打印結(jié)果如下(換行是我自己處理的):

[{'name': '小C', 'age': 12, 'score': 90},
{'name': '小F', 'age': 12, 'score': 88},
{'name': '小D', 'age': 13, 'score': 84},
{'name': '小A', 'age': 14, 'score': 85}, 
{'name': '小E', 'age': 15, 'score': 89}]

那么原來的cmp參數(shù)有的功能實現(xiàn)不了了嗎?當然能,可以通過從functools庫里引入cmp_to_key來解決,看下面幾個例子:

1.數(shù)組的倒序

from functools import cmp_to_key
list = [5,4,3,2,1]
list.sort(key=cmp_to_key(lambda a,b: b-a))
print(list)

打印結(jié)果如下:

[5, 4, 3, 2, 1]

2.把數(shù)組排成最小的數(shù)里python的解法可以通過如下方式解答(注意倒數(shù)第3行,把map類型轉(zhuǎn)成了list類型):

from functools import cmp_to_key

class Solution:
    def PrintMinNumber(self, numbers):
        numbers = list(map(str, numbers))
        numbers.sort(key=cmp_to_key(lambda s1, s2: int(s1+s2) - int(s2+s1)))
        return "".join(numbers)

由于sort只有l(wèi)ist類型才可以用,所以用的更普遍的是sorted方法。

感謝你能夠認真閱讀完這篇文章,希望小編分享python中sort()排序的方法內(nèi)容對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!

向AI問一下細節(jié)

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

AI