Python map和reduce函式用法示例

2022-10-03 13:06:10 字數 1828 閱讀 9581

先看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,...