在Python中,lambda函數是一個簡單的匿名函數。該函數沒有函數名,它可以有多個參數,但函數只由一個表達式構成。
成都創(chuàng)新互聯公司是一家集網站建設,無極企業(yè)網站建設,無極品牌網站建設,網站定制,無極網站建設報價,網絡營銷,網絡優(yōu)化,無極網站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯網需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網站。
lambda函數具體的格式如下:
lambda 參數 : 表達式
其中, lambda 是關鍵字, 參數 是函數的參數,可以有0至多個。冒號后面是表達式,也是該函數中的唯一的表達式,lambda函數會返回該表達式的返回值。
我們來看一個具體的例子。
在上述代碼中,number1, number2是lambda函數的參數,number1**2+number**2是函數的表達式,該函數返回number1, number2兩個數的平方和。
上述代碼創(chuàng)建了一個lambda函數后將其賦值給變量sum_square, 在print函數中通過sum_square來調用這個lambda函數。
上述的lambda函數完全可用標準的函數來實現,我們可以將上述代碼改寫成下面的代碼。
在代碼中,定義了函數sum_square,該函數包含兩個參數,并執(zhí)行一條語句并將該語句的執(zhí)行結果作為函數返回值。通過上述代碼可以幫助我們更直觀地理解lambda函數。
lambda函數的可讀性較差,那么為什么要有這樣奇怪的匿名函數呢?這個要從lambda的使用場合說起。我們來看下面的代碼。
上述代碼定義了一個數值列表,調用python的內置函數filter來生成一個新的迭代器。 filter函數的第一個參數為一個函數,用于決定過濾的方法;第二個參數為一個可迭代的對象如列表、集合等。filter函數返回一個新的迭代器, 用于獲得滿足第一個函數為真的所有元素。在上述代碼中,我們給filter傳遞的第一個參數是一個匿名函數:lambda number:number%3==0, 該函數在一個數整除3時為True,否則為False. filter函數會創(chuàng)建一個新的迭代器,通過調用上述匿名函數來判斷該元素是否滿足條件,得到所有3的倍數的數。
當然,上述代碼也可以使用正常的函數方式來實現,如下所示:
我們可以看到,所有匿名函數的功能都可以通過標準函數來實現。匿名函數常在調用其它函數(如filter, map等)時作為參數使用。使用匿名函數可以使代碼更為精簡。匿名函數主要用于完成簡單的任務,如果匿名函數過于復雜,會導致可讀性較差,調試起來也比較困難,因此,強烈不建議使用lambda寫天書般的代碼??傊?,要根據實際情況決定是否使用匿名函數。
這里lambda x的x是函數的參數,是lst的元素(這里是一個元組),
x[1]是函數的返回值,是lst元素(元組)的第2個元素即字符串,
所以,lst.sort(key=lambda x:x[1])是以lst元素(元組)的第二個元素為key排序,默認為升序
排序后的lst為[(4, 'four'), (1, 'one'), (3, 'three'), (2, 'two')]
print(lst[3][1][2])是打印排序后的lst中的第4個元素(元組)的第2個元素(字符串)的第3個字符,結果就是打印字符串two的字符o
在Python" // "表示整數除法。
Python其它表達式:
Python的表達式寫法與C/C++類似。只是在某些寫法有所差別。
主要的算術運算符與C/C++類似。+, -, *, /, //, **, ~, %分別表示加法或者取正、減法或者取負、乘法、除法、整除、乘方、取補、取余。
, 表示右移和左移。, |, ^表示二進制的AND, OR, XOR運算。, , ==, !=, =, =用于比較兩個表達式的值,
分別表示大于、小于、等于、不等于、小于等于、大于等于。在這些運算符里面,~, |, ^, , , 必須應用于整數。
擴展資料:
Python使用and, or, not表示邏輯運算。
is, is not用于比較兩個變量是否是同一個對象。in, not in用于判斷一個對象是否屬于另外一個對象。
Python支持“列表推導式”(list comprehension),比如計算0-9的平方和:
sum(x * x for x in range(10))
285
Python使用lambda表示匿名函數。匿名函數體只能是表達式。比如:
add=lambda x, y : x + y
add(3,2)
Python使用y if cond else x表示條件表達式。意思是當cond為真時,表達式的值為y,否則表達式的值為x。相當于C++和Java里的cond?y:x。
Python區(qū)分列表(list)和元組(tuple)兩種類型。list的寫法是[1,2,3],而tuple的寫法是(1,2,3)??梢愿淖僱ist中的元素,而不能改變tuple。
在某些情況下,tuple的括號可以省略。tuple對于賦值語句有特殊的處理。因此,可以同時賦值給多個變量,比如:
x, y=1,2 # 同時給x,y賦值,最終結果:x=1, y=2
特別地,可以使用以下這種形式來交換兩個變量的值:
x, y=y, x #最終結果:y=1, x=2
Python使用'(單引號)和"(雙引號)來表示字符串。與Perl、Unix Shell語言或者Ruby、Groovy等語言不一樣,兩種符號作用相同。一般地,如果字符串中出現了雙引號,就使用單引號來表示字符串;反之則使用雙引號。如果都沒有出現,就依個人喜好選擇。
出現在字符串中的\(反斜杠)被解釋為特殊字符,比如\n表示換行符。表達式前加r指示Python不解釋字符串中出現的\。這種寫法通常用于編寫正則表達式或者Windows文件路徑。
Python支持列表切割(list slices),可以取得完整列表的一部分。支持切割操作的類型有str, bytes, list, tuple等。
它的語法是...[left:right]或者...[left:right:stride]。假定nums變量的值是[1, 3, 5, 7, 8, 13, 20],那么下面幾個語句為真:
nums[2:5] == [5, 7, 8] 從下標為2的元素切割到下標為5的元素,但不包含下標為5的元素。
nums[1:] == [3, 5, 7, 8, 13, 20] 切割到最后一個元素。
nums[:-3] == [1, 3, 5, 7] 從最開始的元素一直切割到倒數第3個元素。
nums[:] == [1, 3, 5, 7, 8, 13, 20] 返回所有元素。改變新的列表不會影響到nums。
nums[1:5:2] == [3, 7] 從下標為1的元素切割到下標為5的元素但不包含下標為5的元素,且步長為2。
參考資料:
百度百科——Python(計算機程序設計語言)
在Python中使用lambda創(chuàng)建匿名函數,所謂的匿名,是指不需要為這個函數指定一個名稱.
匿名函數lambda只是一個表達式,函數體比def簡單的多.
labmda arg1,arg2:expression
使用匿名函數創(chuàng)建常用的函數
無參數匿名函數
t = lambda : True
t() - True
等價于下面的def定義的函數
def func(): return True
func() - true
帶參數匿名函數
lambda x : x 3 求x的三次方
lambda x,y=2:x y 參數允許擁有默認值
匿名函數的調用
直接賦值給一個變量,然后跟普通的函數一樣調用它
c = lambda x,y,z: x * y * z
c(2,3,4)
24
lambda返回一個元組
a = lambda *z : z
a('abc','def')
('abc','def')
返回一個字典
d = lambda **dict:dict
d({"a":2})
{"a":2}
lambda直接后面?zhèn)鲄?/p>
(lambda x,y:x+y)(100,200)#300
大量的實例
字符串聯合,有默認值
x = (lambda x = 'boo',y='too',z='zoo':x+y+z)
x(abc)
和列表聯合使用
L = [lambda x : x 2,lambda x:x 3,lambda x:x**4]
for f in L;
print(f(2)) # 4,8,16
和字典結合使用
key = 'B'
dic = {'A':lambda:2 2,'B':lambda:2 4,'C':lambda:2 *8}
dic key # 8
求最小值
lower = lambda:x,y:x if x y else y
lower(2,5) # 2
和map以及l(fā)ist聯合使用
import sys
showall = lambda x : list(map(sys.stdout.write,x))
showall(['Jerry\n','Sherry\n','Alice\n'])
lambda和map聯合使用
out = lambda *x : sys.out.write(' '.join(map(str,x)))
out('This','is','a','book!\n')
This is a book!
判斷字符串是否以某個字母開頭
print(lambda x : x.startswith('b')('Bob')) # false
lambda 和 map,filter聯合使用
squares = map(lambda x : x**2,rang(10))
filters = filter(lambda x: x5 and x 50,squares)
lambda和sorted聯合使用
death = [('James',32),('Fioman',22),('Yasanlun',35)]
list = sorted(death,key=lambda x : x[1])
求2-50之間的素數
nums = range(2,50 + 1)
for i in nums:
nums = filter(lambda x : x ==i or x %i,nums)
求兩個列表元素的和
a = [1,2,3,4]
b = [5,6,7,8]
sum = map(lambda x,y:x+y,a,b)
求字符串中每個單詞的長度
sentence = "Welcom To Beijing!"
words = sentence.split()
lengths = map(lambda x : len(x),words)