先看map。map()函式接收兩個引數,乙個是函式,乙個是序列,map將傳入的函式依次作用到序列的每程式設計客棧個元素,並把結果作為新的list返回。
舉例說明,比如我們有乙個函式a(x)=x*2,要把這個函式作用在乙個list [1, 2, 3, 4, 5]上,就可以用map()實現如下:
複製** **如下:
>>> def a(x):
... return x * 2
...
>>> map(a, [1,2,3,4
[2, 4, 6, 8, 10]
map傳入的第乙個引數a,即a函式,當然你也可以不用mapwww.cppcns.com函式實現這功能:
複製** **如下:
>>> list =
>>> for i in [1, 2, 3, 4, 5]:
... list.append(a(i))
...
>>> print list
[2, 4, 6, 8, 10]
從**量上來講,map要精簡很多,所以,map()作為高階函式,事實上它把運算規則抽象了,因此,我們不但可以計算簡單的a(x)=x*2,還可以計算任意複雜的函式,比如,把這個list所有數字轉為字串:
複製** **如下:
>>> map(str,[1,2,3,4,5])
['1', '2', '3', '4', '5']
>>>
只需要一行**,就搞定了。讓我們再看和來自顧雪峰python教程的習題:利用map()函式,把使用者輸入的不規範的英文名字,變為首字母大寫,其他小寫的規範名字。輸入:[『adam', 『lisa', 『bart'],輸出:[『adam', 『lisa', 『bart']。作為我個人來說,我可能會先將不規範的英文名全轉換在小寫然後再通過capitalize()函式,將首字母轉換在寫,**如下:
複製** **如下:
>>> def caps(namgercpheglxe):
... return name.capitalize()
...
>>> def lowers(name):
... return name.lower()
...
>>> map(caps, map(lowers,['adam', 'lisa', 'bart']))
['adam', 'lisa', 'bart']
再看reduce的用法。reduce(function, sequence, starting_value):對sequence中的item順序迭代呼叫function,如果有starting_value,還可以作為初始值呼叫,例如可以用來對list求和:
複製** **如下:
>>> def add(x, y):
... return x + y
...
>>> reduce(add, [1, 3, 5, 7, 9])
25>>> reduce(add, range(1, 11))
55>>> reduce(add, range(1, 11),20)
75當然求和運算可以直接用python內建函式sum(),沒必要動用reduce。但是如果要把序列[1,2,3,4,5,6,7]變換成整數1234567,reduce就可以派上用場:
複製** **如下:
>>> def fn(x, y):
... return x * 10 + y
...
>>> reduce(程式設計客棧fn, [1,3,4,5,6,7])
134567
本文標題: python map和reduce函式用法示例
本文位址:
python map方法 python map函式
定義 function 函式名 iterable 乙個序列或者多個序列,實際上這就是function對應的實參 map function,iterable,練習def func1 x 對序列中的每乙個元素乘以10並返回 return x 10 map 會根據提供的函式對指定序列做對映。序列中的每乙個...
Hadoop如何計算map數和reduce數
hadoop在執行乙個mapreduce job之前,需要估算這個job的maptask數和reducetask數。首先分析一下job的maptask數,當乙個job提交時,jobclient首先分析job被拆分的split數量,然後吧job.split檔案放置在hdfs中,乙個job的maptas...
python map函式和lambda函式
1 map函式 map 是 python 內建的高階函式,它接收乙個函式 f 和乙個 list,並通過把函式 f 依次作用在 list 的每個元素上,得到乙個新的 list 並返回。1 當seq只有乙個時,將函式func作用於這個seq的每個元素上,並得到乙個新的seq 例如,對於list 1,2,...