map函數根據提供的函數對指定的序列作映射,定義:
map(function, sequence[,sequence,...])--->list編程
例1函數
>>> map(lambda x:x+2, [1, 2, 3]) [3, 4, 5] >>> map(lambda x:x+2, (1, 2, 3)) [3, 4, 5] >>> map(lambda x:x+2, [1, 2], [1, 2]) Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: <lambda>() takes exactly 1 argument (2 given)
最後這個例子說lambda函數須要傳2個參數(由於後面的列表是2個)spa
例2code
>>> map(lambda x,y:x+y, [1, 2], [1, 2]) [2, 4] >>> map(lambda x,y:x+y, [1, 2], (1,2)) [2, 4]
例3blog
>>> a [{'type': 2, 'ID': 1}, {'type': 4, 'ID': 2}, {'ID': 3}] >>> map(lambda x:x['ID'], a) [1, 2, 3] >>> map(lambda x:x['type'], a) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "<stdin>", line 1, in <lambda> KeyError: 'type'
例子說明,若是其中的一個鍵不存在({'ID':3}不存在type)會報錯。ip
例4string
上面例子中只給了lambda,還能夠用普通的函數it
>>> def func2(x, y): ... return x+y ... >>> map(func2, [1, 2, 3], [3, 2, 1]) [4, 4, 4] >>> >>> def func1(x): ... return x**2 ... >>> map(func1, [1, 2, 3]) [1, 4, 9]
例5io
若是沒有給定,就相似於zip函數了ast
>>> map(None, [1, 2, 3, 4], [1, 2, 3, 4]) [(1, 1), (2, 2), (3, 3), (4, 4)] >>> map(None, [1, 2, 3, 4], [1, 2, 3, 4,5]) [(1, 1), (2, 2), (3, 3), (4, 4), (None, 5)] >>> map(None, [1, 2, 3, 4], [1, 2, 3, 4,5], [1, 2, 3]) [(1, 1, 1), (2, 2, 2), (3, 3, 3), (4, 4, None), (None, 5, None)]
不過與zip不一樣
>>> zip([1, 2, 3, 4], [1, 2, 3, 4,5], [1, 2, 3])
[(1, 1, 1), (2, 2, 2), (3, 3, 3)]
filter函數對指定的序列進行過濾操做。定義:
filter(function or None, sequence) -> list, tuple, or string
例1
>>> filter(lambda x:x%2==1, [1, 2, 3]) [1, 3] >>> filter(lambda x:x%2==1, (1, 2, 3)) (1, 3)
reduce函數會對參數序列中元素進行累積。定義:
reduce(function, sequence[, initial]) -> value
注:function必須是有2個參數的函數
例1
>>> reduce(lambda x, y:x+y, [1,2,3,4]) 10 >>> reduce(lambda x, y:x+y, [1,2,3,4], 10) 20
若是沒有initial參數,這麼算:(((1+2)+3)+4)
若是有initial參數,這麼算: ((((10+1)+2)+3)+4)
編程中提到的 lambda 表達式,一般是在須要一個函數,可是又不想費神去命名一個函數的場合下使用,也就是指匿名函數。
舉例對比(列表中的元素平方):
>>> map(lambda x:x*x, range(5)) [0, 1, 4, 9, 16] >>> def sq(x): ... return x * x ... >>> map(sq, range(5)) [0, 1, 4, 9, 16]
map(lambda x:x*x, range(5))