Python中的map、reduce和filter淺析
1、先看看什么是 iterable 對(duì)象
以內(nèi)置的max函數(shù)為例子,查看其doc:
>>> print max.__doc__
max(iterable[, key=func]) -> value
max(a, b, c, ...[, key=func]) -> value
With a single iterable argument, return its largest item.
With two or more arguments, return the largest argument.
在max函數(shù)的第一種形式中,其第一個(gè)參數(shù)是一個(gè) iterable 對(duì)象,既然這樣,那么哪些是 iterable 對(duì)象呢?
>>> max('abcx')
>>> 'x'
>>> max('1234')
>>> '4'
>>> max((1,2,3))
>>> 3
>>> max([1,2,4])
>>> 4
我們可以使用yield生成一個(gè)iterable 對(duì)象(也有其他的方式):
def my_range(start,end):
''' '''
while start <= end:
yield start
start += 1
執(zhí)行下面的代碼:
for num in my_range(1, 4):
print num
print max(my_range(1, 4))
將輸出:
1
2
3
4
4
2、map
在http://docs.python.org/2/library/functions.html#map中如此介紹map函數(shù):
map(function, iterable, ...)
Apply function to every item of iterable and return a list of the results. If additional iterable arguments are passed, function must take that many arguments and is applied to the items from all iterables in parallel. If one iterable is shorter than another it is assumed to be extended with None items. If function is None, the identity function is assumed; if there are multiple arguments, map() returns a list consisting of tuples containing the corresponding items from all iterables (a kind of transpose operation). The iterable arguments may be a sequence or any iterable object; the result is always a list.
map函數(shù)使用自定義的function處理iterable中的每一個(gè)元素,將所有的處理結(jié)果以list的形式返回。例如:
def func(x):
''' '''
return x*x
print map(func, [1,2,4,8])
print map(func, my_range(1, 4))
運(yùn)行結(jié)果是:
[1, 4, 16, 64]
[1, 4, 9, 16]
也可以通過列表推導(dǎo)來實(shí)現(xiàn):
print [x*x for x in [1,2,4,8]]
3、reduce
在http://docs.python.org/2/library/functions.html#reduce中如下介紹reduce函數(shù):
reduce(function, iterable[, initializer])
Apply function of two arguments cumulatively to the items of iterable, from left to right, so as to reduce the iterable to a single value. For example, reduce(lambda x, y: x+y, [1, 2, 3, 4, 5]) calculates ((((1+2)+3)+4)+5). The left argument, x, is the accumulated value and the right argument, y, is the update value from the iterable. If the optional initializer is present, it is placed before the items of the iterable in the calculation, and serves as a default when the iterable is empty. If initializer is not given and iterable contains only one item, the first item is returned.
這個(gè)已經(jīng)介紹的很明了,
相當(dāng)于計(jì)算
((((1+2)+3)+4)+5)
而:
reduce(lambda x, y: x+y, [1, 2, 3, 4, 5],6)
相當(dāng)于計(jì)算
(((((6+1)+2)+3)+4)+5)
4、filter
在http://docs.python.org/2/library/functions.html#filter中如下介紹filter函數(shù):
filter(function, iterable)
Construct a list from those elements of iterable for which function returns true. iterable may be either a sequence, a container which supports iteration, or an iterator. If iterable is a string or a tuple, the result also has that type; otherwise it is always a list. If function is None, the identity function is assumed, that is, all elements of iterable that are false are removed.
Note that filter(function, iterable) is equivalent to [item for item in iterable if function(item)] if function is not None and [item for item in iterable if item] if function is None.
參數(shù)function(是函數(shù))用于處理iterable中的每個(gè)元素,如果function處理某元素時(shí)候返回true,那么該元素將作為list的成員而返回。比如,過濾掉字符串中的字符a:
def func(x):
''' '''
return x != 'a'
print filter(func, 'awake')
運(yùn)行結(jié)果是:
wke
這也可以通過列表推導(dǎo)來實(shí)現(xiàn):
print ''.join([x for x in 'awake' if x != 'a'])
相關(guān)文章
Python如何實(shí)現(xiàn)SSH遠(yuǎn)程連接與文件傳輸
這篇文章主要介紹了Python如何實(shí)現(xiàn)SSH遠(yuǎn)程連接與文件傳輸問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05PyQt5每天必學(xué)之QSplitter實(shí)現(xiàn)窗口分隔
這篇文章主要介紹了PyQt5每天必學(xué)之窗口分隔,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04python使用pygame創(chuàng)建精靈Sprite
這篇文章主要介紹了使用Pygame創(chuàng)建精靈Sprite,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04詳解Python+Selenium+ChromeDriver的配置和問題解決
這篇文章主要介紹了Python+Selenium+ChromeDriver的配置和問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01Python連接達(dá)夢(mèng)數(shù)據(jù)庫(kù)的實(shí)現(xiàn)示例
本文主要介紹了Python連接達(dá)夢(mèng)數(shù)據(jù)庫(kù)的實(shí)現(xiàn)示例,dmPython是DM提供的依據(jù)Python DB API version 2.0中API使用規(guī)定而開發(fā)的數(shù)據(jù)庫(kù)訪問接口,使Python應(yīng)用程序能夠?qū)M數(shù)據(jù)庫(kù)進(jìn)行訪問2023-12-12向量化操作改進(jìn)數(shù)據(jù)分析工作流的Pandas?Numpy示例分析
這篇文章主要介紹了向量化操作改進(jìn)數(shù)據(jù)分析工作流的Pandas?Numpy示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10詳細(xì)聊聊為什么Python中0.2+0.1不等于0.3
最近在學(xué)習(xí)過程中發(fā)現(xiàn)在計(jì)算機(jī)JS時(shí)發(fā)現(xiàn)了一個(gè)非常有意思事,0.1+0.2的結(jié)果不是0.3,而是0.30000000000000004,下面這篇文章主要給大家介紹了關(guān)于為什么Python中0.2+0.1不等于0.3的相關(guān)資料,需要的朋友可以參考下2022-12-12