sort()與sorted()的區別


1,sort(cmp = None ,key = None, reverse = False),沒有返回值,函數用於對原列表進行排序,如果指定參數,則使用比較函數指定的比較函數。會修改list本身,不會返回新list。

cmp:可選參數, 如果指定了該參數會使用該參數的方法進行排序。

key:可選參數,主要是用來進行比較的元素,只有一個參數,具體的函數的參數就是取自於可迭代對象中,指定可迭代對象中的一個元素來進行排序。

reverse:排序規則,reverse = True 降序, reverse = False 升序(默認)。

注意:sort()不能對dict字典進行排序

2, sorted(cmp = None ,key = None, reverse = False),有返回值,

cmp:可選參數, 如果指定了該參數會使用該參數的方法進行排序。

key:可選參數,參數的值為一個函數,此函數只有一個參數且返回一個值用來進行比較。這個技術是快速的因為key指定的函數將准確地對每個元素調用。

reverse:排序規則,reverse = True 降序, reverse = False 升序(默認)。

例子:

1.對dict排序默認會按照dict的key值進行排序,最后返回的結果是一個對key值排序好的list。

my_dict = {"a":"1", "c":"3", "b":"2"}
result = sorted(my_dict)
print result

#輸出: ['a', 'b', 'c']

2.對復雜的元組排序

復制代碼
student_tuples = [
        ('john', 'A', 15),
        ('jane', 'B', 12),
        ('dave', 'B', 10),
]
result = sorted(student_tuples, key=lambda student: student[2])
print result

#輸出 [('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

以上可以看出排序是按照10, 12, 15值進行排序的,因為函數lambda student:student[2]返回的值分別是10, 12, 15。

所以就用函數返回的值進行比較;key=15 ,key=12,key=10根據這些返回值進行比較;

lambda student:student[2] 等價於

def f(student):

    return student[2]

3.根據字典的value排序

默認sorted是對dict的key排序的,如果要根據dict的value排序就需要指定key參數了

復制代碼
my_dict = {"a":"2", "c":"5", "b":"1"}

result = sorted(my_dict)
print result
#默認對dict排序,不指定key參數,會默認對dict的key值進行比較排序
#result輸出: ['a', 'b', 'c']

result2 = sorted(my_dict, key=lambda x:my_dict[x])
print result2
#指定key參數,根據dict的value排序
#result2輸出:['b', 'a', 'c']
復制代碼

sorted()的reverse參數接受False 或者True 表示是否逆序

sorted()還有的參數例如cmp參數這里就不做多介紹了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM