Python中map和reduce詳解

map()函數接收兩個參數,一個是函數,一個是序列,map將傳入的函數依次作用到序列的每個元素,並把結果作爲新的list返回。

實例:map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9])=['1', '2', '3', '4', '5', '6', '7', '8', '9']

reduce()把一個函數作用在一個序列[x1, x2, x3...]上,這個函數必須接收兩個參數,reduce把結果繼續和序列的下一個元素做累積計算,其效果就是:

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

實例:reduce(add, [1, 3, 5, 7, 9])=25

還可嵌套使用:reduce(lambda x,y: x*10+y, map(int, ['1','2','3','4','5']))

map()實例:利用map()函數,把用戶輸入的不規範的英文名字,變爲首字母大寫,其他小寫的規範名字

def normalize(name):  
   name=name[0].upper()+name[1:].lower()  
   return name  
a= ['adam', 'LISA', 'barT']  
b= list(map(normalize, a))  
print(b)  


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