python基礎(chǔ)之匿名函數(shù)介紹
前言
在定義函數(shù)的時候,不想給函數(shù)起一個名字。這個時候就可以用lambda來定義一個匿名函數(shù)
語法:
變量名= lambda 參數(shù):表達式(block)
參數(shù):可選,通常以逗號分隔的變量表達式形式,也就是位置參數(shù)
表達式:不能包含循環(huán)、return,可以包含if…else…
注意:
1.表達式中不能包含 循環(huán),return.可以包含 if…else…語句.
2.參數(shù)可有可無,如果有多個參數(shù),使用逗號隔開
3.表達式計算的結(jié)果直接返回
一、創(chuàng)建一個匿名函數(shù):
func = lambda: 3 > 2
ret = func() # 調(diào)用匿名函數(shù),變量名(),使用變量ret來接收表達式返回的內(nèi)容
print(ret) #True
def func():
return 3 > 2
ret = func()
print(ret) #True
# 和func=lambda :3>2 等價
運行結(jié)果:
True True

二、創(chuàng)建一個帶參數(shù)的匿名函數(shù)
def func(x, y):
return x + y
ret = func(1, 2)
print(ret) #3
#匿名函數(shù)
func = lambda x, y: x + y
ret = func(1, 2) # 如果匿名函數(shù)有參數(shù),調(diào)用匿名函數(shù)的時候需要傳遞實參。
print(ret) #3
三、求兩個數(shù)的中的最大的值
def func(x, y):
if x < y:
return y
else:
return x
ret = func(30, 20)
print(ret) #30
#匿名函數(shù)
func = lambda x, y: y if x < y else x
# 注意if和else 沒有 : 不能換行,if判斷體寫在判斷條件前面
ret = func(11, 2)
print(ret) #11
func = lambda x, y: y if x < y else x

四、練習(xí)題:
1.將add()方法改成匿名函數(shù)
def add(x, y):
return x + y
func = lambda x, y: x + y
ret = func(1, 2)
print(ret) # 3
2.使用 max函數(shù)求字典的最大值
dic = {'k1': 10, 'k2': 200, 'k3': 20}
ret = max(dic) # 默認(rèn)比較的是字典的key的大小。ASCII對于的十進制
print(ret) # k3
def func(key):
return dic[key]
ret = max(dic, key=func) # 改變比較規(guī)則,用value比較大小,最終返回的函數(shù)是字典的key值
print(ret) # k2
使用匿名函數(shù)
ret = max(dic, key=lambda x: dic[x])
print(ret) #k2

3、根據(jù)列表中字典‘name'對應(yīng)的valuez值進行比較
lst = [
{'name': 'egon', 'price': 100},
{'name': 'rdw', 'price': 666},
{'name': 'zat', 'price': 1}
]
# ret = max(lst) # 報錯,字典之間不能比較。
# print(ret)
def max_name(dic):
return dic['name'] # 返回 字典 name對應(yīng)的值
ret = max(lst, key=max_name) # 指定比較內(nèi)容
print(ret)
使用匿名函數(shù)進行比較:
ret = max(lst, key=lambda dic: dic['name']) # 指定比較內(nèi)容
print(ret)
運行結(jié)果:
{'name': 'zat', 'price': 1}
{'name': 'zat', 'price': 1}

同理可以根據(jù)列表中字典‘price'對應(yīng)的valuez值大小進行比較
lst = [
{'name': 'egon', 'price': 100},
{'name': 'rdw', 'price': 666},
{'name': 'zat', 'price': 1}
]
def max_price(dic):
return dic['price'] # 返回 字典 price 的值
匿名函數(shù):
ret = max(lst, key=lambda dic: dic['price']) # 指定比較內(nèi)容 100,666,1
print(ret) #{'name': 'rdw', 'price': 666}
4、求 lst 中每一個元素的平方值
lst = [1, 3, 4]
def square(num):
num2 = num * num
return num2
ret = map(square, lst) # 迭代器 1,4,16
for i in ret:
print(i) # 1,9,16
匿名函數(shù):
ret = map(lambda num: num * num, lst)
for i in ret:
print(i) # 1,9,16

5.過濾出列表中的所有奇數(shù):
lst = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
def odd(num):
if num % 2 == 1:
return True
else:
return False
ret = filter(odd, lst)
print(list(ret)) #[1, 3, 5, 7, 9]
# 匿名函數(shù):
ret = filter(lambda num: True if num % 2 == 1 else False, lst)
print(list(ret)) #[1, 3, 5, 7, 9]

6、現(xiàn)有兩個元組((‘a(chǎn)'),(‘b')),((‘c'),(‘d')),請使用python中匿名函數(shù)生成列表[{‘a(chǎn)':‘c'},{‘b':‘d'}]
tup1 = (('a'), ('b'))
tup2 = (('c'), ('d'))
# [{'a':'c'},{'b':'d'}]
ret = zip(tup1, tup2) #(('a','c'),('b','d'))
def func(tup):
#('a','c') ('b','d')
return {tup[0],tup[1]}
ret1=map(func,ret)
print(list(ret1)) #[{'a': 'c'}, {'b': 'd'}]
# 匿名函數(shù):
ret2 = list(map(lambda tup: {tup[0]: tup[1]}, ret))
print(ret2) #[{'a': 'c'}, {'b': 'd'}]

到此這篇關(guān)于python基礎(chǔ)之匿名函數(shù)介紹的文章就介紹到這了,更多相關(guān)python匿名函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
citespace數(shù)據(jù)處理:用python對Ref文檔進行去重方式
這篇文章主要介紹了citespace數(shù)據(jù)處理:用python對Ref文檔進行去重方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11
Python異常處理如何才能寫得優(yōu)雅(retrying模塊)
異常就是程序運行時發(fā)生錯誤的信號,下面這篇文章主要給大家介紹了關(guān)于Python異常處理的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-03-03
python print出共軛復(fù)數(shù)的方法詳解
在本篇內(nèi)容里小編給大家分享的是關(guān)于python print出共軛復(fù)數(shù)的方法總結(jié)內(nèi)容,有需要的讀者們可以學(xué)習(xí)下。2019-06-06
python將MongoDB里的ObjectId轉(zhuǎn)換為時間戳的方法
這篇文章主要介紹了python將MongoDB里的ObjectId轉(zhuǎn)換為時間戳的方法,涉及Python操作MongoDB及字符串轉(zhuǎn)換的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03
TensorFlow可視化工具TensorBoard默認(rèn)圖與自定義圖
這篇文章主要介紹了TensorFlow可視化工具TensorBoard默認(rèn)圖與自定義圖的使用操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10
解決Jupyter Notebook開始菜單欄Anaconda下消失的問題
這篇文章主要介紹了解決Jupyter Notebook開始菜單欄Anaconda下消失的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04

