今天來給大家推薦一個Python當中超級好用的內建函數,那便是lambda方法,本篇教程大致和大家分享:
在Python當中,我們經常使用lambda關鍵字來宣告一個匿名函數,所謂地匿名函數,通俗地來講就是沒有名字的函數,具體的語法格式如下所示:
lambda arguments : expression
其中它可以接受任意數量的參數,但是只允許包含一個表達式,而該表達式的運算結果就是函數的傳回值,我們可以簡單地來寫一個例子:
(lambda x:x**2)(5)
output:
25
那麼我們如何來過濾列表當中的元素呢?這裡就需要將lambda函數和filter()方法結合起來使用了,而filter()方法的語法格式:
filter(function, iterable)
import numpy as np yourlist = list(np.arange(2,50,3))
lambda x:x**2<100
list(filter(lambda x:x**2<100, yourlist))
[2, 5, 8]
lambda x: x**2+x**3
list(map(lambda x: x**2+x**3, yourlist))
[12, 150, 576, 1452, 2940, 5202, ......]
mylist = list(np.arange(4,52,3)) yourlist = list(np.arange(2,50,3))
list(map(lambda x,y: x**2+y**2, yourlist,mylist))
[20, 74, 164, 290, 452, 650, 884, 1154, ......]
myseries = pd.Series(mylist) myseries
04 17 2 10 3 13 4 16 5 19 6 22 7 25 8 28 ...... dtype: int32
myseries.apply(lambda x: (x+5)/x**2)
0 0.562500 1 0.244898 2 0.150000 3 0.106509 4 0.082031 5 0.066482 6 0.055785 7 0.048000 ...... dtype: float64
df = pd.read_csv(r'Dummy_Sales_Data_v1.csv') df["Sales_Manager"] = df["Sales_Manager"].apply(lambda x: x.upper()) df["Sales_Manager"].head()
0PABLO 1PABLO 2KRISTEN 3ABDUL 4 STELLA Name: Sales_Manager, dtype: object
squared_sum = lambda x,y: x**2 + y**2 squared_sum(3,4)
def squared_sum(x,y): return x**2 + y**2 squared_sum(3,4)
25
import math mylist = [10, 25, 40, 49, 65, 81] sqrt_list = list(map(lambda x: math.sqrt(x), mylist)) sqrt_list
[3.16227766, 5.0, 6.324555320, 7.0, 8.062257748, 9.0]
import math mylist = [10, 25, 40, 49, 65, 81] sqrt_list = list(map(math.sqrt, mylist)) sqrt_list
[3.162277, 5.0, 6.324555, 7.0, 8.062257, 9.0]
以上是淺談Python當中Lambda函數的用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!