Python自學記錄——高階函數map/reduce、filter、sorted

Python內置了四個強大的函數,如標題所示,下面來記錄說明下:

map

看見此 map 需要注意,python中的 map 和 java 中的 map,是不同的,java中的 map 與 python中的字典列表相近。

map是一個十分便利的函數,它可以將list中的每個值執行相同的函數方法,並返回一個新的迭代器對象Iterator,示例如下:

>>> l = [1,2,3,4,5]
>>> def pf(num):
...     return num * num
...
>>> map(pf,l)
<map object at 0x0000000001E5F160>
>>> #爲了方便看結果,用list()把Iterator對象轉換成list
>>> list(map(pf,l))
[1, 4, 9, 16, 25]

上述示例中,是將一個包含若干整數的 list 執行 pf 方法,使其得到一個Iterator,並將其轉化爲list。

map作爲高階函數,可以執行更多複雜的操作,比如,將整型list轉爲字符型list,示例如下:

>>> l2 = [1,2,3,4,5]
>>> list(map(str,l2))
['1', '2', '3', '4', '5']

總結下:使用map函數,需要向其傳入兩個參數,第一個爲 可迭代對象Iterable 中元素待執行的方法(簡稱函數),第二個爲需要執行可迭代對象 Iterator ,如下所示:

map(函數,可迭代對象)

使用它方便,簡單又快捷。

reduce

reduce的使用方法和map類似,它是把函數作用在一個序列上,需要的可迭代對象至少需要兩個元素,示例如下:

reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)

使用reduce前,需要導入函數,具體寫法如下:

from functools import reduce

它可實現整數字符串 list 轉爲一個整數,示例如下:

>>> l3 = [1,2,3,4,5]
>>> def list2num(x,y):
...     return x * 10 + y
...
>>> from functools import reduce
>>> reduce(list2num,l3)
12345

藉此,我們可以實現很多事情,下面以浮點字符串,轉浮點型爲例,結合 map 和 reduce 寫個例子:

>>> import test
>>> test.str2float('123.456')
123.456

上述代碼調用了這個函數的方法:

from functools import reduce
DIGITS = {'0':0,'1':1,'2':2,'3':3,'4':4,'5':5,'6':6,'7':7,'8':8,'9':9}
def str2float(num):
	znum = num[:num.index('.')]
	xnum = num[num.index('.')+1:]
	xn = len(xnum)
	def getnum(num):
		return DIGITS[num]
	z = list(map(getnum,znum))
	x = list(map(getnum,xnum))	
	def list2num(x,y):
		return x*10 + y	
	nznum = reduce(list2num,z)
	nxnum = reduce(list2num,x)
	return nznum+ nxnum*pow(0.1,xn)

filter

filter是一個列表過濾器,它可以根據條件過濾出列表中你想要的元素,使用起來也很簡單,示例如下:

def t_test1(n):
    return n % 2 == 1
list(filter(t_test1,[1,2,3,4,5,6,7]))
[1,3,5,7]

它的使用方法也很簡單,需要傳兩個參數,一個是根據函數內置條件返回 True 或 False的函數;另一個是可迭代對象Iterator。

filter()把傳入的函數依次作用與每個元素,然後根據返回值是 True 或 False 決定是保留還是丟棄該元素。

把一個序列的中的空字符刪除,寫法如下:

def t_t1(n):
    return n and n.strip()
L4 = ['123','a','','  ',None]
list(filter(t_t1,L4))
['123','a']

sorted

sorted是Python內置的一個排序函數,它可以快速便捷的將列表中的元素排序,示例如下:

>>> L = [1,20,-19,25,30,-2]
>>> sorted(L)
[-19, -2, 1, 20, 25, 30]
>>> L2 = ['abc','good','Cat','DOG','CAKE']
>>> sorted(L2)
['CAKE', 'Cat', 'DOG', 'abc', 'good']

如上述示例所示,sorted函數自動將列表中的元素按照大小進行排序,其中,字符傳是根據ASCII碼自字符串首位開始比較的。

使用它時,還可以給排序加入條件,比如,數字按絕對值大小排序,字符串按全小寫來排序,示例如下:

>>> L = [1,20,-19,25,30,-2]
>>> sorted(L,key=abs)
[1, -2, -19, 20, 25, 30]
>>> L2 = ['abc','good','Cat','DOG','CAKE']
>>> sorted(L2,key=str.lower)
['abc', 'CAKE', 'Cat', 'DOG', 'good']

如果想得到反向排列的列表,添加一個參數即可,示例如下:

>>> L = [1,20,-19,25,30,-2]
>>> sorted(L,key=abs,reverse=True)
[30, 25, 20, -19, -2, 1]
>>> L2 = ['abc','good','Cat','DOG','CAKE']
>>> sorted(L2,key=str.lower,reverse=True)
['good', 'DOG', 'Cat', 'CAKE', 'abc']

sorted可以使代碼更簡潔,它很強大。

本篇就到這裏,教材網址:https://www.liaoxuefeng.com, 繼續學習~~

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章