①從引數方面來講:
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 這段...