Python排序之多屬性排序


 

1.sort函數說明:

sort函數是list類的一個方法,說明如下:

sort(...)
L.sort(cmp=None, key=None, reverse=False) -- stable sort *IN PLACE*;
cmp(x, y) -> -1, 0, 1

其中,包含三個參數cmp,key,reverse:cmp用於指定排序的大小比較算法;key用於制定排序的維度和優先級別;reverse說明是否是逆序排列(True表示從大到小)

 

2.實例

 

2.1讓元組按照第一維度升序,第二維度也是升來排序。(或者都是逆序)



students.sort(key=lambda l:(l[0],l[1]),reverse=True)
students.sort(key=lambda l:(l[0],l[1]))

 

 

2.2讓一組升序,一組數據降序排列:

def mycmp(a,b):
if a[0]>b[0]:
return 1
if a[0]<b[0]:
 return -1
if a[1]<b[1]:
 return 1
if a[1]>b[1]:
return -1
return 0
if __name__=="__main__":
#students.sort(key=lambda l:(l[0],l[1]),reverse=True)
students.sort(cmp=mycmp)


3.python的內置函數sort



a = [5,2,1,9,6] 
>>> sorted(a) #將a從小到大排序,不影響a本身結構 
[1, 2, 5, 6, 9] 
>>> sorted(a,reverse = True) #將a從大到小排序,不影響a本身結構 
[9, 6, 5, 2, 1] 
>>> a.sort() #將a從小到大排序,影響a本身結構 
>>> a 
[1, 2, 5, 6, 9] 
>>> a.sort(reverse = True) #將a從大到小排序,影響a本身結構 
>>> a 
[9, 6, 5, 2, 1] 
注意,a.sort() 已改變其結構,b = a.sort() 是錯誤的寫法! 
>>> b = ['aa','BB','bb','zz','CC'] 
>>> sorted(b) 
['BB', 'CC', 'aa', 'bb', 'zz'] #按列表中元素每個字母的ascii碼從小到大排序,如果要從大到小,請用sorted(b,reverse=True)下同 
>>> c =['CCC', 'bb', 'ffff', 'z'] 
>>> sorted(c,key=len) #按列表的元素的長度排序 
['z', 'bb', 'CCC', 'ffff'] 
>>> d =['CCC', 'bb', 'ffff', 'z'] 
>>> sorted(d,key = str.lower ) #將列表中的每個元素變為小寫,再按每個元素中的每個字母的ascii碼從小到大排序 
['bb', 'CCC', 'ffff', 'z'] 
>>> def lastchar(s): 
return s[-1] 
>>> e = ['abc','b','AAz','ef'] 
>>> sorted(e,key = lastchar) #自定義函數排序,lastchar為函數名,這個函數返回列表e中每個元素的最后一個字母 
['b', 'abc', 'ef', 'AAz'] #sorted(e,key=lastchar)作用就是 按列表e中每個元素的最后一個字母的ascii碼從小到大排序 
>>> f = [{'name':'abc','age':20},{'name':'def','age':30},{'name':'ghi','age':25}] #列表中的元素為字典 
>>> def age(s): 
return s['age'] 
>>> ff = sorted(f,key = age) #自定義函數按列表f中字典的age從小到大排序 
[{'age': 20, 'name': 'abc'}, {'age': 25, 'name': 'ghi'}, {'age': 30, 'name': 'def'}] 
>>> f2 = sorted(f,key = lambda x:x['age']) #如果覺得上面定義一個函數代碼不美觀,可以用lambda的形式來定義函數,效果同上 

 


免責聲明!

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



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