欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

Lambda函數(shù)怎么在Python項目中使用-創(chuàng)新互聯(lián)

這期內(nèi)容當中小編將會給大家?guī)碛嘘PLambda函數(shù)怎么在Python項目中使用,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

目前成都創(chuàng)新互聯(lián)公司已為近1000家的企業(yè)提供了網(wǎng)站建設、域名、虛擬空間、網(wǎng)站托管、服務器租用、企業(yè)網(wǎng)站設計、金鄉(xiāng)網(wǎng)站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

lambda表達式是一種匿名函數(shù),對應python中的自定義函數(shù)def,是定義某個函數(shù)時比較高級的一種寫法。作為python初學者,本文整理了lambda的一些基本用法和特點。

lambda和def的對應關系

定義func函數(shù),計算給定數(shù)x的平方

def func(x):
return x*x

等價于

func = lambda x: x*x

其中func是函數(shù)名,x是輸入?yún)?shù),x*x是輸出結果

輸入?yún)?shù)可以有多個,可以接收不定參數(shù)如*args或者**kwargs。

f = lambda x, *args, para, **kwargs : [args, para, kwargs]
f(1, 2, 3, para='number', name='Jack', sex='male')
# 輸出 [(2, 3), 'number', {'name': 'Jack', 'sex': 'male'}]

有時也可以不指定輸入?yún)?shù),如:

lambda: random.randn()

lambda與map(), filter(), reduce()

lambda表達式返回一個函數(shù),這個函數(shù)可以作為其他函數(shù)的參數(shù)。常用的可以與lambda組合的內(nèi)置函數(shù)有map(), filter(), reduce().

在處理一個可迭代對象如列表,字典等時,可以用map(lambda, x) 代替 for...in...循環(huán),如:

lst = [1, 2, 3, 4, 5]
res = []
for i in lst:
  a = i*i
  res.append(a)

等價于

res = list(map(lambda x:x*x, lst))

可以看到這里的lambda生成的函數(shù)直接作為map函數(shù)的function參數(shù),對列表的每一個元素進行平方計算

同理可以將lambda用于filter進行篩選,或者reduce累積運算:

from functools import reducelst = [1, 2, 3, 4, 5]f_res = filter(lambda x: x>3, lst)
r_res = reduce(lambda x, y: x*y, lst)

print('大于3的數(shù)字有:', list(f_res)) 
print('累乘結果為:', r_res)

輸出結果:

大于3的數(shù)字有: [4, 5]
累乘結果為: 120

lambda與if條件判斷

lambda表達式中可以插入if...else進行條件判斷,如

f = lambda x: 'even' if x%2==0 else 'odd'
# f(3)輸出結果 odd

等價于

def f(x):<br data-filtered="filtered">  if x%2==0:<br data-filtered="filtered">    return 'even'<br data-filtered="filtered">  else:<br data-filtered="filtered">    return 'odd'

注意如果在lambda中使用if進行條件判斷,則else是必須聲明的,否則會引起報錯。如果不返回結果可以用 else None 表示。

if...elif...else的多條件判斷也可以用于lambda,但會使得代碼過于復雜,所以不推薦。

lambda在pandas中的使用

lambda函數(shù)常用于DataFrame或者Series對象下的map、apply、transform方法

import pandas as pd
df = pd.DataFrame({'Age': [22, 21, 22, 21, 20], 'Score': [87, 66, 79, 54, 59]})
df['Pass'] = df.apply(lambda x: 'pass' if x[1]>=60 else 'Not pass', axis=1)

輸出新列 'Pass',根據(jù)成績判斷通過與否,輸出df后結果為:

  Age Score  Pass
0  22 87 pass
1  21 66 pass
2  22 79 pass
3  21 54 Not pass
4  20 59 Not pass

x為DataFrame對象,當參數(shù)axis=1時,x[1]等于第二列。

當用于Series對象時,以上代碼等價于:

df['Pass'] = df['Score'].apply(lambda x: 'pass' if x>60 else 'Not pass')

在pandas中,通過apply,map, transform方法,lambda可以直接應用于Series級別的運算。

當使用applymap方法時,lambda可以應用于DataFrame級別的運算。

lamda的優(yōu)缺點

lambda的優(yōu)點:

  • 不需要定義函數(shù)名(匿名函數(shù))

  • 代碼簡潔美觀

  • 適用于定義簡單的計算

lambda的缺點:

  • 只有一個運算式,不適用于復雜的計算

  • 不夠直觀,難于理解,增加了維護成本

上述就是小編為大家分享的Lambda函數(shù)怎么在Python項目中使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

本文題目:Lambda函數(shù)怎么在Python項目中使用-創(chuàng)新互聯(lián)
分享路徑:http://www.chinadenli.net/article26/ddcecg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷全網(wǎng)營銷推廣網(wǎng)站排名外貿(mào)網(wǎng)站建設云服務器Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設