<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          好用!Python Lambda函數(shù)的幾種用法

          共 3803字,需瀏覽 8分鐘

           ·

          2022-10-20 00:26

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

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

          什么是Lambda函數(shù)

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

          lambda arguments : expression

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

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

          output

          25

          過濾列表中的元素

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

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

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

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

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

          lambda x:x**2<100

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

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

          output

          [2, 5, 8]

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

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

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

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

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

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

          output

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

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

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

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

          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()方法我們都需要將可迭代對象放入其中,而這里的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

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

          不太適合使用的場景

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

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

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

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

          output

          25

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

          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]

          我們可以將其簡化成

          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ù)中,可以直接抽出來用

          我們的文章到此就結(jié)束啦,如果你喜歡今天的Python 實(shí)戰(zhàn)教程,請持續(xù)關(guān)注Python實(shí)用寶典。

          有任何問題,可以在公眾號后臺回復(fù):加群,回答相應(yīng)紅字驗(yàn)證信息,進(jìn)入互助群詢問。

          原創(chuàng)不易,希望你能在下面點(diǎn)個(gè)贊和在看支持我繼續(xù)創(chuàng)作,謝謝!

          點(diǎn)擊下方閱讀原文可獲得更好的閱讀體驗(yàn)

          Python實(shí)用寶典 (pythondict.com)
          不只是一個(gè)寶典
          歡迎關(guān)注公眾號:Python實(shí)用寶典


          瀏覽 48
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評論
          圖片
          表情
          推薦
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  豆花无码一区二区三区 | 毛片网页| 久久久成人精品视频 | 免费看又爽又黄 | 免费在线黄色小视频 |