欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入了解Python中Lambda函數(shù)的用法

 更新時(shí)間:2022年09月13日 09:31:51   作者:欣一  
lambda函數(shù)是Python中常用的內(nèi)置函數(shù),又稱(chēng)為匿名函數(shù)。和普通函數(shù)相比,它只有函數(shù)體,省略了def和return,使得結(jié)構(gòu)看起來(lái)更精簡(jiǎn)。本文將詳細(xì)說(shuō)說(shuō)Lambda函數(shù)的用法,需要的可以參考一下

今天來(lái)給大家推薦一個(gè)Python當(dāng)中超級(jí)好用的內(nèi)置函數(shù),那便是lambda方法,本篇教程大致和大家分享

  • 什么是lambda函數(shù)
  • lambda函數(shù)過(guò)濾列表元素
  • lambda函數(shù)和map()方法的聯(lián)用
  • lambda函數(shù)和apply()方法的聯(lián)用
  • 什么時(shí)候不適合使用lambda方法

什么是Lambda函數(shù)

在Python當(dāng)中,我們經(jīng)常使用lambda關(guān)鍵字來(lái)聲明一個(gè)匿名函數(shù),所謂地匿名函數(shù),通俗地來(lái)講就是沒(méi)有名字的函數(shù),具體的語(yǔ)法格式如下所示

lambda?arguments?:?expression

其中它可以接受任意數(shù)量的參數(shù),但是只允許包含一個(gè)表達(dá)式,而該表達(dá)式的運(yùn)算結(jié)果就是函數(shù)的返回值,我們可以簡(jiǎn)單地來(lái)寫(xiě)一個(gè)例子

(lambda?x:x**2)(5)

output

25

過(guò)濾列表中的元素

那么我們?nèi)绾蝸?lái)過(guò)濾列表當(dāng)中的元素呢?這里就需要將lambda函數(shù)和filter()方法聯(lián)合起來(lái)使用了,而filter()方法的語(yǔ)法格式

filter(function,?iterable)
  • function -- 判斷函數(shù)
  • iterable -- 可迭代對(duì)象,列表或者是字典

其中我們有這么一個(gè)列表

import?numpy?as?np
yourlist?=?list(np.arange(2,50,3))

其中我們想要過(guò)濾出2次方之后小于100的元素,我們來(lái)定義一個(gè)匿名函數(shù),如下

lambda?x:x**2<100

最后出來(lái)的結(jié)果如下所示

list(filter(lambda?x:x**2<100,?yourlist))

output

[2, 5, 8]

要是遇上復(fù)雜的計(jì)算過(guò)程,小編這里還是推薦大家自己自定義一個(gè)函數(shù),但若是簡(jiǎn)單的計(jì)算過(guò)程,lambda匿名函數(shù)絕對(duì)是最佳的選擇

和map()函數(shù)的聯(lián)用

map()函數(shù)的語(yǔ)法和上面的filter()函數(shù)相近,例如下面這個(gè)匿名函數(shù)

lambda?x:?x**2+x**3

我們將其和map()方法聯(lián)用起來(lái)

list(map(lambda?x:?x**2+x**3,?yourlist))

output

[12,
 150,
 576,
 1452,
 2940,
 5202,
 ......]

當(dāng)然正如我們之前提到的lambda匿名函數(shù)可以接受多個(gè)數(shù)量的參數(shù),我們這里就可以來(lái)嘗試一下了,例如有兩組列表,

mylist = list(np.arange(4,52,3))
yourlist = list(np.arange(2,50,3))

我們同樣使用map()方法來(lái)操作,代碼如下

list(map(lambda?x,y:?x**2+y**2,?yourlist,mylist))

output

[20,
 74,
 164,
 290,
 452,
 650,
 884,
 1154,
......]

和apply()方法的聯(lián)用

apply()方法在Pandas的數(shù)據(jù)表格中用的比較多,而在apply()方法當(dāng)中就帶上lambda匿名函數(shù),我們新建一個(gè)數(shù)據(jù)表格,如下所示

myseries = pd.Series(mylist)
myseries

output

0      4
1      7
2     10
3     13
4     16
5     19
6     22
7     25
8     28
......
dtype: int32

apply()方法的使用和前兩者稍有不同,map()方法和filter()方法我們都需要將可迭代對(duì)象放入其中,而這里的apply()則不需要

myseries.apply(lambda?x:?(x+5)/x**2)

output

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

而要是遇到DataFarme表格數(shù)據(jù)的時(shí)候,也是同樣地操作

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()

output

0      PABLO
1      PABLO
2    KRISTEN
3      ABDUL
4     STELLA
Name: Sales_Manager, dtype: object

并且通過(guò)apply()方法處理可是比直接用str.upper()方法來(lái)處理,速度來(lái)的更快哦??!

不太適合使用的場(chǎng)景

那么不適合的場(chǎng)景有哪些呢?那么首先lambda函數(shù)作為一個(gè)匿名函數(shù),不適合將其賦值給一個(gè)變量,例如下面的這個(gè)案例

squared_sum = lambda x,y: x**2 + y**2
squared_sum(3,4)

相比較而言更好的是自定義一個(gè)函數(shù)來(lái)進(jìn)行處理

def squared_sum(x,y):
    return x**2 + y**2
  
squared_sum(3,4)

output

25

而我們遇到如下情景的時(shí)候,可以對(duì)代碼稍作簡(jiǎn)化處理

import math
mylist = [10, 25, 40, 49, 65, 81]
sqrt_list = list(map(lambda x: math.sqrt(x), mylist))
sqrt_list

output

[3.16227766, 5.0, 6.324555320, 7.0, 8.062257748, 9.0]

我們可以將其簡(jiǎn)化成

import math
mylist = [10, 25, 40, 49, 65, 81]
sqrt_list = list(map(math.sqrt, mylist))
sqrt_list

output

[3.162277, 5.0, 6.324555, 7.0, 8.062257, 9.0]

如果是Python當(dāng)中的內(nèi)置函數(shù),尤其是例如math這種用于算數(shù)的模塊,可以不需要放在lambda函數(shù)中,可以直接抽出來(lái)用

到此這篇關(guān)于深入了解Python中Lambda函數(shù)的用法的文章就介紹到這了,更多相關(guān)Python Lambda函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python數(shù)據(jù)分析必會(huì)的Pandas技巧匯總

    python數(shù)據(jù)分析必會(huì)的Pandas技巧匯總

    用Python做數(shù)據(jù)分析光是掌握numpy和matplotlib可不夠,numpy雖然能夠幫我們處理處理數(shù)值型數(shù)據(jù),但很多時(shí)候,還有字符串,還有時(shí)間序列等,比如:我們通過(guò)爬蟲(chóng)獲取到了存儲(chǔ)在數(shù)據(jù)庫(kù)中的數(shù)據(jù),一些Pandas必會(huì)的用法,讓你的數(shù)據(jù)分析水平更上一層樓
    2021-08-08
  • python3啟動(dòng)web服務(wù)引發(fā)的一系列問(wèn)題匯總

    python3啟動(dòng)web服務(wù)引發(fā)的一系列問(wèn)題匯總

    由于行內(nèi)交付的機(jī)器已自帶python3 ,沒(méi)有采取自行安裝python3,但是運(yùn)行python腳本時(shí)報(bào)沒(méi)有tornado module,遇到這樣的問(wèn)題如何處理呢,下面小編給大家介紹下python3啟動(dòng)web服務(wù)引發(fā)的一系列問(wèn)題匯總,感興趣的朋友一起看看吧
    2023-02-02
  • pthon貪吃蛇游戲詳細(xì)代碼

    pthon貪吃蛇游戲詳細(xì)代碼

    這篇文章主要為大家詳細(xì)介紹了Python貪吃蛇游戲詳細(xì)代碼和注釋?zhuān)哂幸欢ǖ膮⒖純r(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Python如何將函數(shù)值賦給變量

    Python如何將函數(shù)值賦給變量

    這篇文章主要介紹了Python如何將函數(shù)值賦給變量,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 解決Shell執(zhí)行python文件,傳參空格引起的問(wèn)題

    解決Shell執(zhí)行python文件,傳參空格引起的問(wèn)題

    今天小編就為大家分享一篇解決Shell執(zhí)行python文件,傳參空格引起的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • pandas數(shù)據(jù)聚合與分組運(yùn)算的實(shí)現(xiàn)

    pandas數(shù)據(jù)聚合與分組運(yùn)算的實(shí)現(xiàn)

    本文主要介紹了pandas數(shù)據(jù)聚合與分組運(yùn)算的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • python的urllib.parse用法及說(shuō)明

    python的urllib.parse用法及說(shuō)明

    這篇文章主要介紹了python的urllib.parse用法及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Sublime?Text4?配置?Python3?環(huán)境、代碼提示、編譯報(bào)錯(cuò)的解決方案

    Sublime?Text4?配置?Python3?環(huán)境、代碼提示、編譯報(bào)錯(cuò)的解決方案

    這篇文章主要介紹了Sublime?Text4?配置?Python3?環(huán)境、代碼提示、編譯報(bào)錯(cuò)教程,通過(guò)圖文并茂的形式給大家介紹了配置自動(dòng)代碼提示的方法,需要的朋友可以參考下
    2022-01-01
  • Python如何解決secure_filename對(duì)中文不支持問(wèn)題

    Python如何解決secure_filename對(duì)中文不支持問(wèn)題

    最近使用到了secure_filename,然后悲劇的發(fā)現(xiàn)中文居然不展示出來(lái),本文就詳細(xì)的介紹一下解決方法,感興趣的可以了解一下
    2021-07-07
  • python安裝pandas庫(kù)不成功原因分析及解決辦法

    python安裝pandas庫(kù)不成功原因分析及解決辦法

    Pandas是python中非常常用的數(shù)據(jù)分析庫(kù),在數(shù)據(jù)分析、機(jī)器學(xué)習(xí)、深度學(xué)習(xí)等領(lǐng)域經(jīng)常被使用,下面這篇文章主要給大家介紹了關(guān)于python安裝pandas庫(kù)不成功原因分析及解決辦法的相關(guān)資料
    2023-11-11

最新評(píng)論