網站首頁 編程語言 正文
今天來給大家推薦一個Python
當中超級好用的內置函數,那便是lambda
方法,本篇教程大致和大家分享
- 什么是
lambda
函數 -
lambda
函數過濾列表元素 -
lambda
函數和map()
方法的聯用 -
lambda
函數和apply()
方法的聯用 - 什么時候不適合使用
lambda
方法
什么是Lambda函數
在Python當中,我們經常使用lambda
關鍵字來聲明一個匿名函數,所謂地匿名函數,通俗地來講就是沒有名字的函數,具體的語法格式如下所示
lambda?arguments?:?expression
其中它可以接受任意數量的參數,但是只允許包含一個表達式,而該表達式的運算結果就是函數的返回值,我們可以簡單地來寫一個例子
(lambda?x:x**2)(5)
output
25
過濾列表中的元素
那么我們如何來過濾列表當中的元素呢?這里就需要將lambda
函數和filter()
方法聯合起來使用了,而filter()
方法的語法格式
filter(function,?iterable)
- function -- 判斷函數
- iterable -- 可迭代對象,列表或者是字典
其中我們有這么一個列表
import?numpy?as?np yourlist?=?list(np.arange(2,50,3))
其中我們想要過濾出2次方之后小于100的元素,我們來定義一個匿名函數,如下
lambda?x:x**2<100
最后出來的結果如下所示
list(filter(lambda?x:x**2<100,?yourlist))
output
[2, 5, 8]
要是遇上復雜的計算過程,小編這里還是推薦大家自己自定義一個函數,但若是簡單的計算過程,lambda
匿名函數絕對是最佳的選擇
和map()函數的聯用
map()
函數的語法和上面的filter()
函數相近,例如下面這個匿名函數
lambda?x:?x**2+x**3
我們將其和map()
方法聯用起來
list(map(lambda?x:?x**2+x**3,?yourlist))
output
[12,
?150,
?576,
?1452,
?2940,
?5202,
?......]
當然正如我們之前提到的lambda
匿名函數可以接受多個數量的參數,我們這里就可以來嘗試一下了,例如有兩組列表,
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()方法的聯用
apply()
方法在Pandas
的數據表格中用的比較多,而在apply()
方法當中就帶上lambda
匿名函數,我們新建一個數據表格,如下所示
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
表格數據的時候,也是同樣地操作
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
函數作為一個匿名函數,不適合將其賦值給一個變量,例如下面的這個案例
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)
output
25
而我們遇到如下情景的時候,可以對代碼稍作簡化處理
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
當中的內置函數,尤其是例如math
這種用于算數的模塊,可以不需要放在lambda
函數中,可以直接抽出來用
原文鏈接:https://mp.weixin.qq.com/s/xbJQJNifaOAv8UUF78Ilvg
相關推薦
- 2022-07-26 ES對比兩個索引的數據差
- 2022-05-06 CSRF攻擊是什么?如何防范CSRF攻擊?_安全相關
- 2022-10-31 Kotlin擴展函數超詳細介紹_Android
- 2022-02-07 SSH連服務器提示“Permission denied,please try again”的原因與解
- 2022-10-27 python使用pika庫調用rabbitmq交換機模式詳解_python
- 2022-12-26 層次分析法在matlab上的實現方式_python
- 2022-03-31 C#值類型、引用類型、泛型、集合、調用函數的表達式樹實踐_C#教程
- 2022-03-15 React?Router?V6更新內容詳解_React
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支