Python中map和reduce函式

2022-08-01 01:27:13 字數 1183 閱讀 4401

①從引數方面來講:

map()函式:

map()包含兩個引數,第乙個是引數是乙個函式,第二個是序列(列表或元組)。其中,函式(即map的第乙個引數位置的函式)可以接收乙個或多個引數。

reduce()函式:

reduce() 第乙個引數是函式,第二個是 序列(列表或元組)。但是,其函式必須接收兩個引數。

②從對傳進去的數值作用來講:

map()是將傳入的函式依次作用到序列的每個元素,每個元素都是獨自被函式「作用」一次;(請看下面的栗子)

reduce()是將傳人的函式作用在序列的第乙個元素得到結果後,把這個結果繼續與下乙個元素作用(累積計算),

最終結果是所有的元素相互作用的結果。(請看下面的栗子)

舉個栗子:

map()函式:

[python]

# 傳入乙個引數  

def one_p(x):  

return x * x  

print 'map1.1:', map(one_p, range(1, 5))   

#結果:map1.1: [1, 4, 9, 16]  

print 'map1.2:', map(one_p, [1, 2, 3, 4, 5, 6])  

#結果:map1.2: [1, 4, 9, 16, 25, 36]  

# 傳入多個引數  

a = [1, 2, 3, 4, 5]  

b = [1, 1, 6, 2, 3]  

c = [1, 2, 3, 4, 5]  

s = map(lambda (x, y, z): x * y * z, zip(a, b, c))  

print 'map2:', s  

#結果:map2: [1, 4, 54, 32, 75]  

reduce()函式:

[python]

r1 = reduce(lambda x, y: x * y, (2, 2, 6, 2))  #運算過程:(((2*2)*6)*2)  

r2 = reduce(lambda x, y: x * y, (2, 2, 6), 2)  #運算過程:(((2*2)*6)*2)

print 'r1:', r1  # 結果:r1: 48  

print 'r2:', r2  # 結果:r2: 48 

Python中map和reduce函式??

從引數方面來講 map 函式 map 包含兩個引數,第乙個是引數是乙個函式,第二個是序列 列表或元組 其中,函式 即map的第乙個引數位置的函式 可以接收乙個或多個引數。reduce 函式 reduce 第乙個引數是函式,第二個是 序列 列表或元組 但是,其函式必須接收兩個引數。從對傳進去的數值作用...

python中map和zip的用法

1,map 是python的乙個內建函式,它接收乙個函式和乙個可迭代物件 如列表 作為引數,用函式處理每個元素,然後返回新的列表。l1 1 2 3 4 5 print map int,l1 輸出 1,2,3,4,5 print map lambda x int x 2,l1 輸出 2,4,5,8,1...

Python 中 map和reduce 的用法

首先是map 接受兩個引數,第乙個是函式,第二個是乙個可迭代的的引數 iterable 如下例子,我們定義乙個函式f x x 2 map的用法 deffunc x return x x m map func,range 1,8 print list m 輸出 1,4,9,16,25,36,49 這段...