map
map()函數(shù)接收兩個參數(shù)米罚,一個是函數(shù)髓窜,一個是序列征讲,map將傳入的函數(shù)依次作用到序列的每個元素据某,并把結(jié)果作為新的list返回。
- 方式一:接收一個參數(shù)
>>> 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]
等價于
L = []
for n in [1, 2, 3, 4, 5, 6, 7, 8, 9]:
L.append(f(n))
print L
- 方式二:接收兩個參數(shù)
>>> print map(lambda x , y : x ** y, [2,4,6],[3,2,1])
[8, 16, 6]
如果上面我們不使用map函數(shù)诗箍,就只能使用for循環(huán)癣籽,依次對每個位置的元素調(diào)用該函數(shù)去執(zhí)行。還可以使返回值是一個元組。如:
>>> print map(lambda x , y : (x ** y, x + y), [2,4,6],[3,2,1])
[(8, 5), (16, 6), (6, 7)]
- 方式三:無function函數(shù)筷狼,相當于zip函數(shù)
當func函數(shù)時None時橱夭,這就同zip()函數(shù)了,并且zip()開始取代這個了桑逝,目的是將多個列表相同位置的元素歸并到一個元組棘劣。如:
>>> print map(None, [2,4,6],[3,2,1])
[(2, 3), (4, 2), (6, 1)]
>>> map(int, (1,2,3))
[1, 2, 3] ***將元組轉(zhuǎn)換成list***
>>> map(int, '1234')
[1, 2, 3, 4] ***將字符串轉(zhuǎn)換成list***
>>> map(int, {1:2,2:3,3:4})
[1, 2, 3] ***提取字典的key,并將結(jié)果存放在一個list中***
>>> map(tuple, 'agdf')
[('a',), ('g',), ('d',), ('f',)]
***字符串轉(zhuǎn)換成元組楞遏,并將結(jié)果以列表的形式返回***
def u_to_l (s):
return s.upper()
print map(u_to_l,'asdfd’) #將小寫轉(zhuǎn)成大寫
reduce
reduce把一個函數(shù)作用在一個序列[x1, x2, x3...]上茬暇,這個函數(shù)必須接收兩個參數(shù),reduce把結(jié)果繼續(xù)和序列的下一個元素做累積計算寡喝。
def myadd(x,y):
return x+y
sum=reduce(myadd,(1,2,3,4,5,6,7))
print sum
結(jié)果就是輸出1+2+3+4+5+6+7的結(jié)果即28
當然糙俗,也可以用lambda的方法,更為簡單:
sum=reduce(lambda x,y:x+y,(1,2,3,4,5,6,7))
print sum
filter
filter()也接收一個函數(shù)和一個序列预鬓。和map()不同的時巧骚,filter()把傳入的函數(shù)依次作用于每個元素,然后根據(jù)返回值是True還是False決定保留還是丟棄該元素格二。
def is_odd(n):
return n % 2 == 1
filter(is_odd, [1, 2, 4, 5, 6, 9, 10, 15])
[1, 5, 9, 15]
lambda
>>> map(lambda x: x * x, [1, 2, 3, 4, 5, 6, 7, 8, 9])
[1, 4, 9, 16, 25, 36, 49, 64, 81]
匿名函數(shù)lambda x: x * x實際上就是:
def f(x):
return x * x