久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

python中List的sort方法(或者sorted內(nèi)建函數(shù))的用法

 dbn9981 2016-09-16
     python列表排序

簡單記一下python中List的sort方法(或者sorted內(nèi)建函數(shù))的用法,。

關(guān)鍵字:
python列表排序 python字典排序 sorted


List的元素可以是各種東西,,字符串,字典,,自己定義的類等,。

sorted函數(shù)用法如下:
Python代碼  收藏代碼
  1. sorted(data, cmp=None, key=None, reverse=False)  

其中,data是待排序數(shù)據(jù),,可以使List或者iterator, cmp和key都是函數(shù),,這兩個函數(shù)作用與data的元素上產(chǎn)生一個結(jié)果,sorted方法根據(jù)這個結(jié)果來排序,。
cmp(e1, e2) 是帶兩個參數(shù)的比較函數(shù), 返回值: 負(fù)數(shù): e1 < e2, 0: e1 == e2, 正數(shù): e1 > e2. 默認(rèn)為 None, 即用內(nèi)建的比較函數(shù).
key 是帶一個參數(shù)的函數(shù), 用來為每個元素提取比較值. 默認(rèn)為 None, 即直接比較每個元素.
通常, key 和 reverse 比 cmp 快很多, 因?yàn)閷γ總€元素它們只處理一次; 而 cmp 會處理多次.

通過例子來說明sorted的用法:

1. 對由tuple組成的List排序
Python代碼  收藏代碼
  1. >>> students = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10),]  


用key函數(shù)排序(lambda的用法見 注釋1)
Python代碼  收藏代碼
  1. >>> sorted(students, key=lambda student : student[2])   # sort by age  
  2. [('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]  


用cmp函數(shù)排序
Python代碼  收藏代碼
  1. >>> sorted(students, cmp=lambda x,y : cmp(x[2], y[2])) # sort by age  
  2. [('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]  


用 operator 函數(shù)來加快速度, 上面排序等價(jià)于:(itemgetter的用法見 注釋2)
Python代碼  收藏代碼
  1. >>> from operator import itemgetter, attrgetter  
  2. >>> sorted(students, key=itemgetter(2))  


用 operator 函數(shù)進(jìn)行多級排序
Python代碼  收藏代碼
  1. >>> sorted(students, key=itemgetter(1,2))  # sort by grade then by age  
  2. [('john', 'A', 15), ('dave', 'B', 10), ('jane', 'B', 12)]  



2. 對由字典排序
Python代碼  收藏代碼
  1. >>> d = {'data1':3, 'data2':1, 'data3':2, 'data4':4}  
  2. >>> sorted(d.iteritems(), key=itemgetter(1), reverse=True)  
  3. [('data4', 4), ('data1', 3), ('data3', 2), ('data2', 1)]  


注釋1
參考:http:///2011/10/29/introduce-to-python-lambda.html

注釋2
參考:http://ar./thread-90745710c90cf1.html
class itemgetter(__builtin__.object)
|  itemgetter(item, ...) --> itemgetter object
|
|  Return a callable object that fetches the given item(s) from its operand.
|  After, f=itemgetter(2), the call f(r) returns r[2].
|  After, g=itemgetter(2,5,3), the call g(r) returns (r[2], r[5], r[3])

相當(dāng)于
Python代碼  收藏代碼
  1. def itemgetter(i,*a):   
  2.     def func(obj):   
  3.         r = obj[i]   
  4.         if a:   
  5.             r = (r,) + tuple(obj[i] for i in a)   
  6.         return r   
  7.     return func   
  8.   
  9. >>> a = [1,2,3]   
  10. >>> b=operator.itemgetter(1)   
  11. >>> b(a)   
  12. 2   
  13. >>> b=operator.itemgetter(1,0)   
  14. >>> b(a)   
  15. (2, 1)   
  16. >>> b=itemgetter(1)   
  17. >>> b(a)   
  18. 2   
  19. >>> b=itemgetter(1,0)   
  20. >>> b(a)   
  21. (2, 1)   


參考資料:
1. http://www./linuxbiancheng/13340.html
2. http://www.douban.com/note/13460891/   

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,,所有內(nèi)容均由用戶發(fā)布,,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購買等信息,,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,,請點(diǎn)擊一鍵舉報(bào),。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多