人人都能學會的python程式設計教程16:map和reduce

程式設計老司機發表於2018-05-10

如果你學習過大資料相關知識一定不會陌生MapReduce。

如果你沒有學過大資料,也沒關係,本文將帶你瞭解python的map和reduce函式。

map()

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

舉例說明,比如我們有一個函式f(x)=2x,要把這個函式作用在一個list [1, 2, 3, 4, 5, 6, 7, 8, 9]上,就可以用map()實現如下:

寶寶都能學會的python程式設計教程16:map和reduce

reduce()

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

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

寶寶都能學會的python程式設計教程16:map和reduce

相關文章