一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python中的map()函數和reduce()函數的用法

Python中的map()函數和reduce()函數的用法

2020-06-14 09:46廖雪峰 Python

這篇文章主要介紹了Python中的map()函數和reduce()函數的用法,代碼基于Python2.x版本,需要的朋友可以參考下

Python內建了map()和reduce()函數。

如果你讀過Google的那篇大名鼎鼎的論文“MapReduce: Simplified Data Processing on Large Clusters”,你就能大概明白map/reduce的概念。

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

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

Python中的map()函數和reduce()函數的用法

現在,我們用Python代碼實現:

?
1
2
3
4
5
>>> def f(x):
...   return x * x
...
>>> map(f, [1, 2, 3, 4, 5, 6, 7, 8, 9])
[1, 4, 9, 16, 25, 36, 49, 64, 81]

map()傳入的第一個參數是f,即函數對象本身。

你可能會想,不需要map()函數,寫一個循環,也可以計算出結果:

?
1
2
3
4
L = []
for n in [1, 2, 3, 4, 5, 6, 7, 8, 9]:
  L.append(f(n))
print L

的確可以,但是,從上面的循環代碼,能一眼看明白“把f(x)作用在list的每一個元素并把結果生成一個新的list”嗎?

所以,map()作為高階函數,事實上它把運算規則抽象了,因此,我們不但可以計算簡單的f(x)=x2,還可以計算任意復雜的函數,比如,把這個list所有數字轉為字符串:

?
1
2
>>> map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9])
['1', '2', '3', '4', '5', '6', '7', '8', '9']

只需要一行代碼。

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

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

比方說對一個序列求和,就可以用reduce實現:

?
1
2
3
4
5
>>> def add(x, y):
...   return x + y
...
>>> reduce(add, [1, 3, 5, 7, 9])
25

當然求和運算可以直接用Python內建函數sum(),沒必要動用reduce。

但是如果要把序列[1, 3, 5, 7, 9]變換成整數13579,reduce就可以派上用場:

?
1
2
3
4
5
>>> def fn(x, y):
...   return x * 10 + y
...
>>> reduce(fn, [1, 3, 5, 7, 9])
13579

這個例子本身沒多大用處,但是,如果考慮到字符串str也是一個序列,對上面的例子稍加改動,配合map(),我們就可以寫出把str轉換為int的函數:

?
1
2
3
4
5
6
7
8
>>> def fn(x, y):
...   return x * 10 + y
...
>>> def char2num(s):
...   return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[s]
...
>>> reduce(fn, map(char2num, '13579'))
13579

整理成一個str2int的函數就是:

?
1
2
3
4
5
6
def str2int(s):
  def fn(x, y):
    return x * 10 + y
  def char2num(s):
    return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[s]
  return reduce(fn, map(char2num, s))

還可以用lambda函數進一步簡化成:

?
1
2
def char2num(s):
  return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[s]
?
1
2
def str2int(s):
  return reduce(lambda x,y: x*10+y, map(char2num, s))

也就是說,假設Python沒有提供int()函數,你完全可以自己寫一個把字符串轉化為整數的函數,而且只需要幾行代碼!

練習

利用map()函數,把用戶輸入的不規范的英文名字,變為首字母大寫,其他小寫的規范名字。輸入:['adam', 'LISA', 'barT'],輸出:['Adam', 'Lisa', 'Bart']。

Python提供的sum()函數可以接受一個list并求和,請編寫一個prod()函數,可以接受一個list并利用reduce()求積。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 全黄h全肉细节文在线观看 全彩成人18h漫画 | 人生路不在线观看完整版 | 亚洲国产成人久久综合一区77 | 护士伦理片 | 大陆男同志gayxxx | 精品国产爱久久 | 精品卡1卡2卡三卡免费视频 | 美国69xxxx59| 91天堂影院 | 天天久久综合网站 | 天天视频国产精品 | 午夜爱| 翁用力的抽插 | 5g影院天天影院天天爽影院网站 | 美女国内精品自产拍在线播放 | 热门小说同人h改编h | 色噜噜狠狠狠综合曰曰曰88av | 成人综合网址 | 精品美女国产互换人妻 | 贰佰麻豆剧果冻传媒一二三区 | 国产视频久久久久 | 91看片在线观看 | 草草剧场| 亚洲精品综合 | m3u8久久国产精品影院 | 亚洲成年网站在线777 | 国产一区二区播放 | 亚洲国产成人精品无码区APP | 俺去俺去啦最新官网在线 | 日本免费一区二区三区四区五六区 | x8x8在线观看免费 | 波多野结衣在线免费观看 | 亚洲成人国产 | www.99精品视频在线播放 | 精品无码国产AV一区二区三区 | 亚洲欧美精品一区天堂久久 | 麻豆在线传煤 | 国产精品免费久久久久影院小说 | 国产成人综合久久 | 色哟哟观看 | 蜜臀91|