每個 Python 高手都應該知道的內建函式

菜鳥學Python發表於2017-04-01

python內建了一些非常巧妙而且強大的內建函式,對初學者來說,一般不怎麼用到,我也是用了一段時間python之後才發現,哇還有這麼好的函式,這個函式都是經典的而且經過嚴格測試的,可以一下子省了你原來很多事情,程式碼不僅簡潔易讀了很多,而且不用自己去閉門造車.既方便了自己又減少了bug。

1.sorted()

1)對於一個列表排序

sorted([100, 98, 102, 1, 40])
>>>[1, 40, 98, 100, 102]

2)通過key引數/函式

比如一個長列表裡面巢狀了很多字典元素,我們要按照每個元素的長度大小排序

L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]
new_line=sorted(L,key=lambda x:len(x))
print(new_line)
>>>[{1: 9}, {1: 5, 3: 4}, {1: 3, 6: 3}, {1: 1, 2: 4, 5: 6}]

3)對由tuple組成的List排序

比如下面是學生裡面的年齡的一個list

students = [('wang', 'A', 15), ('li', 'B', 12), ('zhang', 'B', 10)]   
print(sorted(students, key=lambda student : student[2]))  
>>>[('zhang', 'B', 10), ('li', 'B', 12), ('wang', 'A', 15)]

4)用cmp函式排序 

students = [('wang', 'A', 15), ('li', 'B', 12), ('zhang', 'B', 10)]   
print(sorted(students, cmp=lambda x,y : cmp(x[0], y[0])) )
>>>[('li', 'B', 12), ('wang', 'A', 15), ('zhang', 'B', 10)]

其實對於python的排序要仔細講,需要一整篇幅講它的排序演算法,內容非常多,感興趣的可以去看一下原始碼,看它是如何設計的,這裡只是先點一下.

2.map()

map可以根據提供的函式對指定序列做對映,它接受一個函式f和一個list,並通過把函式f以此作用在list上的每個元素,然後返回一個新的list,map函式的入參也可以是多個.注意這個函式一定要有返回值(值值值重要的說三遍)。

不然就會返回新的list 類似[None, None, None, None, None, None, None, None, None]

適合的場景是對列表裡面的一些元素需要重複的操作,用map就可以輕鬆搞定.

3.enumerate()

Python中,迭代永遠是取出元素本身,而非元素的索引,有的時候我們需要知道元素的索引比如在一個很長的列表裡面是一些網站名,我們希望在列印的時候,也能列出索引。若沒有這個函式,我們需要在加一個變數,在迴圈列印的時候讓這個計數變數遞增,現在有了enumerate,就不用這麼麻煩了,直接搞定.

4.zip()

zip函式接受任意多個(包括0個和1個)序列作為引數,返回一個tuple列表

x = [1, 2, 3]
y = [4, 5, 6]
z = [7, 8, 9]
xyz = zip(x, y, z)
>>print xyz

這個函式特別是在構建字典序列的時候非常方便 (這招非常巧妙,大家可以仔細揣摩)

5.filter()

filter函式接受一個函式f和一個list,這個函式f的作用是對每個元素進行判斷,返回True或者False,這樣可以過濾掉一些不符合條件的元素,然後返回符合條件的list.

def is_even(x):
	return x%2==0
print(filter(is_even,[1,2,3,4,5]))
>>>[2, 4]

特別是在處理檔案的時候,需要把一些空格,回車和空字元去掉


6.reduce()

reduce函式的用法和map很類似,也是一個函式f和一個list,但是函式的入口引數一定要是兩個,reduce也是對每個元素進行反覆呼叫,最後返回最終的值,而map是返回一個list

注意在python3裡面reduce已經從全域性函式裡面移除了,需要用的話要from functools import reduce

最後說一下,我堅持原創,若我寫的對大家有幫助,麻煩大家鼓勵,轉發或者關注一下,長按下發二維碼即可,也是對我的一點支援。

相關文章