- 論壇徽章:
- 0
|
在python中使用lambda來(lái)創(chuàng)建匿名函數(shù)。lambda來(lái)源于LISP語(yǔ)言。lambda的形式如下:
lambda會(huì)創(chuàng)建一個(gè)函數(shù)對(duì)象,但不會(huì)把這個(gè)函數(shù)對(duì)象賦給一個(gè)標(biāo)識(shí)符,而def則不同,它在創(chuàng)建函數(shù)對(duì)象的同時(shí)會(huì)進(jìn)行這種操作。這是lambda的第一個(gè)特點(diǎn)。lambda的第二個(gè)特點(diǎn)是,它只是一個(gè)表達(dá)式,而不是一個(gè)語(yǔ)句。如果單獨(dú)使它成為了一個(gè)語(yǔ)句,比如:
如果你在你的python程序中寫(xiě)下了這么一行,那么毫無(wú)意義,這一行代碼會(huì)創(chuàng)建一個(gè)函數(shù)對(duì)象,但馬上又給丟棄了,因?yàn)槟銢](méi)有使用它的返回值,即那個(gè)函數(shù)對(duì)象。也正是由于lambda只是一個(gè)表達(dá)式,它可以直接作為list或dictionary的成員,比如:
- L = [lambad x: x**2, lambda x: x**3]
在這個(gè)地方?jīng)]有辦法用def語(yǔ)句直接代替。第三,lambda表達(dá)式在“:”后只能有一個(gè)表達(dá)式。也就是說(shuō),在def中,可以放在return后的也可以放在lambda,不能放在return后也不能放在這里。更本質(zhì)地說(shuō),后面的表達(dá)式是能夠返回一個(gè)值的,不能返回值的不能放在這里。因此,像if或for或print這種語(yǔ)句就不能用于lambda中,lambda一般只用來(lái)定義簡(jiǎn)單的函數(shù)。當(dāng)然,通過(guò)一些技巧,可以在lambda中實(shí)現(xiàn)與if或for相同的功能。比如:if語(yǔ)句可以利用and和or這兩個(gè)邏輯操作符的“短路”特性來(lái)模擬,比如:
- ((test and [x]) or [y])[0]
這樣的話(huà),如果test為真,那么就會(huì)計(jì)算[x],當(dāng)然得到的就是[x],由于在or操作符的左邊已經(jīng)得到真值,or的右邊就不會(huì)被計(jì)算,因此得到的是[x][0],最后的結(jié)果是x。如果test為假,那么根據(jù)and的特性,左邊已經(jīng)為假,右邊不會(huì)被計(jì)算。這時(shí)or的左邊為假那么就得到[y][0],最后的結(jié)果是y。注意在這里不能寫(xiě)成如下的形式:
在x為真值時(shí),這種形式與上面這種形式是等價(jià)的。但設(shè)想這種情況,“如果test為真,則取0,如果test為假,則取[]”,也就是說(shuō)x本身是一個(gè)假值,用上面的形式書(shū)寫(xiě)就是:
顯然不能達(dá)到目的,這個(gè)式子永遠(yuǎn)只會(huì)取到[]。因此應(yīng)該改寫(xiě)成:
- ((test and [0]) or [[]])[0]
在lambda中循環(huán)語(yǔ)句也是可以模擬的,用的是map函數(shù)。比如:
- F=lambda x: map((lambda y: y**2), x)
當(dāng)然,這種東西看起來(lái)就很復(fù)雜,如果可能最好不要嵌套使用lambda。print也是可以模擬的:
import syspp = lambda x: sys.stdout.write(str(x)+'\n')pp(8) ===> 8
本文來(lái)自ChinaUnix博客,如果查看原文請(qǐng)點(diǎn):http://blog.chinaunix.net/u/2809/showart_81032.html |
|