sort函數和sorted函數唯壹的不同是,sort是在容器內排序,sorted生成壹個新的排好序的容器。
對於壹個簡單的數組 L=[5,2,3,1,4].
sort: L.sort()
sorted(...)
sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list
iterable:待排序的可叠代類型的容器;
cmp:用於比較的函數,比較什麽由key決定,有默認值,叠代集合中的壹項;
key:用列表元素的某個已命名的屬性或函數(只有壹個參數並且返回壹個用於排序的值)作為關鍵字,有默認值,叠代集合中的壹項;
reverse:排序規則. reverse = True 或者 reverse = False,有默認值。
返回值:是壹個經過排序的可叠代類型,與iterable壹樣。
如果是壹個多維的列表 L=[(‘b’,2),(‘a’,1),(‘c’,3),(‘d’,4)].
有三種選擇對這個多維列表進行排序
利用cmp函數
sorted(L, cmp=lambda x,y:cmp(x[1],y[1]))
L.sort(cmp=lambda x,y:cmp(x[1],y[1]))
利用key
sorted(L, key=lambda x:x[1]);
L.sort(key=lambda x:x[1]);
反序
以上幾種排序均可加上參數reverse.
例如 sorted(reverse=True), L.sort(reverse=True). 或者改成False
OrderedDict是collections中的壹個包,能夠記錄字典元素插入的順序,常常和排序函數壹起使用來生成壹個排序的字典。
比如,比如壹個無序的字典
d = {‘banana’:3,’apple’:4,’pear’:1,’orange’:2}
通過排序來生成壹個有序的字典,有以下幾種方式
collections.OrderedDict(sorted(d.items(),key = lambda t:t[0]))
或者
collections.OrderedDict(sorted(d.items(),key = lambda t:t[1]))
或者
collections.OrderedDict(sorted(d.items(),key = lambda t:len(t[0])))