1. 程式人生 > >Python進階(十三)-淺談sorted 函式應用

Python進階(十三)-淺談sorted 函式應用

分享一下我的偶像大神的人工智慧教程!http://blog.csdn.net/jiangjunshow

也歡迎轉載我的文章,轉載請註明出處 https://blog.csdn.net/mm2zzyzzp

Python進階(十三)-淺談sorted 函式應用

  眾所周知,def cmp 作為方法存在,用sort對例項進行排序時,會用到class 中的cmp。但是,在python3中,取消了 sorted對cmp的支援。
  python3 中有關排序的sorted方法如下:

sorted(iterable,key=None,reverse=False
)
  • 1

  其中,key接受一個函式,這個函式只接受一個元素,預設為None。
reverse是一個布林值。如果設定為True,列表元素將被倒序排列,預設為False。
  下面著重介紹key的作用原理:
  key指定一個接收一個引數的函式,這個函式用於從每個元素中提取一個用於比較的關鍵字。預設值為None 。

例1

students = [('john', 'A', 15), ('jane', 'B', 12), ('dave','B', 10)]
sorted(students,key=lambda s: x[2]) #按照年齡來排序
  
  • 1
  • 2

  結果:[(‘dave’,’B’, 10), (‘jane’, ‘B’, 12), (‘john’, ‘A’, 15)]

例2

  這是一個字串排序,排序規則:小寫<大寫<奇數<偶數
s = ‘asdf234GDSdsf23’ #排序:小寫-大寫-奇數-偶數

print("".join(sorted(s, key=lambda x: (x.isdigit(),x.isdigit() and int(x) % 2 == 0,x.isupper(),x))))
  
  • 1

  原理:先比較元組的第一個值,如果相等就比較元組的下一個值,以此類推。
  先看一下Boolean value 的排序:
  print(sorted([True,Flase]))===>結果[False,True]
  Boolean 的排序會將 False 排在前,True排在後 .

  • 1.x.isdigit()的作用是把數字放在前邊,字母放在後邊.
  • 2.x.isdigit() and int(x) % 2 == 0的作用是保證奇數在前,偶數在後。
  • 3.x.isupper()的作用是在前面基礎上,保證字母小寫在前大寫在後.
  • 4.最後的x表示在前面基礎上,對所有類別數字或字母排序。

  最後結果:addffssDGS33224

例3

一道面試題:

list1=[7, -8, 5, 4, 0, -2, -5]
#要求1.正數在前負數在後 2.正數從小到大 3.負數從大到小
sorted(list1,key=lambda x:(x<0,abs(x)))
  
  • 1
  • 2
  • 3

  解題思路:先按照正負排先後,再按照大小排先後。


這裡寫圖片描述

給我偶像的人工智慧教程打call!http://blog.csdn.net/jiangjunshow