python3中sort和sorted使用與區(qū)別
sort和sorted的區(qū)別
雖然python3中sort()和sorted()都可以用來排序,但二者有以下兩個最主要的區(qū)別:
sort只能應(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.更復(fù)雜一點的排序:list里的元素是一個字典,通過字典的某個屬性值排序。下面是通過學(xué)生的年齡排序
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方法,下面來說下sorted方法
sorted
所有可以迭代的對象都可以用sorted來進行排序,排序不會改變原來的對象。sorted接收3個參數(shù):
sorted(iterable, *, key=None, reverse=False)
iterable是可迭代的對象,key和reverse與sort里的相同。
看下面一個小例子:
student_tuples = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)] new_tuples = sorted(student_tuples, key=lambda student: student[2]) print(student_tuples) print(new_tuples)
打印結(jié)果如下:
[('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]
新列表是通過年齡排序的,從打印結(jié)果可以看出沒有改變原數(shù)據(jù)
由于這種含有key參數(shù)的方法很普遍,所以python中提供了一些方法使得訪問器函數(shù)更加方便。比如operator模塊中的itemgetter(), attrgetter()方法。
看下下面的例子:
from operator import itemgetter, attrgetter class Student: def __init__(self, name, grade, age): self.name = name self.grade = grade self.age = age student_objects = [Student('john', 'A', 15), Student('jane', 'B', 12), Student('dave', 'B', 10)] student_tuples = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10) ] result1 = sorted(student_tuples, key=itemgetter(2)) # 通過元素的第三個值排序 result2 = sorted(student_objects, key=attrgetter('age')) # 通過對象的age屬性排序 result3 = sorted(student_tuples, key=itemgetter(1,2)) # 首先通過元素的第一個值排序,然后通過第二個值排序 result4 = sorted(student_objects, key=attrgetter('grade', 'age')) # 通過對象的grade屬性排序,后通過age屬性排序
排序后的結(jié)果如下(非打印):
result1與result2:
[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]
result3與result4:
[('john', 'A', 15), ('dave', 'B', 10), ('jane', 'B', 12)]
排序是保證穩(wěn)定可靠的,當排序的key對應(yīng)的值相同時,會保持它們在原數(shù)據(jù)中的順序,比sort里的第3個例子如以下代碼運行結(jié)果:
from operator import itemgetter data = [('red', 1), ('blue', 1), ('red', 2), ('blue', 2)] print(sorted(data, key=itemgetter(0)))
打印結(jié)果
[('john', 'A', 15), ('dave', 'B', 10), ('jane', 'B', 12)]
到此這篇關(guān)于python3中sort和sorted使用與區(qū)別的文章就介紹到這了,更多相關(guān)python3 sort和sorted內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python使用collections模塊實現(xiàn)擴展數(shù)據(jù)類
Python?標準庫提供了一個?collections?模塊,里面提供了很多的數(shù)據(jù)類,在工作中使用這些類能夠簡化我們的開發(fā),本文就來看看collections是如何實現(xiàn)擴展數(shù)據(jù)類的吧2023-06-06使用Python實現(xiàn)將圖片轉(zhuǎn)線條圖
這篇文章主要為大家詳細介紹了如何使用Python實現(xiàn)將圖片轉(zhuǎn)線條圖,可以讓圖片看起來更加的有意思,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-02-02windows環(huán)境下tensorflow安裝過程詳解
這篇文章主要為大家詳細介紹了windows環(huán)境下tensorflow安裝過程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03Pandas實現(xiàn)解析JSON數(shù)據(jù)與導(dǎo)出的示例詳解
其實使用pandas解析JSON?Dataset要方便得多,所以這篇文章主要為大家介紹了Pandas實現(xiàn)解析JSON數(shù)據(jù)與導(dǎo)出的具體方法,需要的小伙伴可以收藏一下2023-07-07Django項目主urls導(dǎo)入應(yīng)用中views的紅線問題解決
這篇文章主要介紹了Django項目主urls導(dǎo)入應(yīng)用中views的紅線問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-08-08用python實現(xiàn)英文字母和相應(yīng)序數(shù)轉(zhuǎn)換的方法
這篇文章主要介紹了用python實現(xiàn)英文字母和相應(yīng)序數(shù)轉(zhuǎn)換的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09