今天来给大家推荐一个Python当中超级好用的内置函数,那便是lambda方法,本篇教程大致和大家分享:
什么是Lambda函数
在Python当中,我们经常使用lambda关键字来声明一个匿名函数,所谓地匿名函数,通俗地来讲就是没有名字的函数,具体的语法格式如下所示
lambdaarguments:expression
其中它可以接受任意数量的参数,但是只允许包含一个表达式,而该表达式的运算结果就是函数的返回值,我们可以简单地来写一个例子
(lambdax:x**2)(5)
output
25
过滤列表中的元素
那么我们如何来过滤列表当中的元素呢?这里就需要将lambda函数和filter()方法联合起来使用了,而filter()方法的语法格式
filter(function,iterable)
function -- 判断函数
其中我们有这么一个列表
importnumpyasnp
yourlist=list(np.arange(2,50,3))
其中我们想要过滤出2次方之后小于100的元素,我们来定义一个匿名函数,如下
lambdax:x**2<100
最后出来的结果如下所示
list(filter(lambdax:x**2<100,yourlist))
output
[2,5,8]
lambda匿名函数绝对是最佳的选择和map()函数的联用
map()函数的语法和上面的filter()函数相近,例如下面这个匿名函数
lambdax:x**2+x**3
我们将其和map()方法联用起来
list(map(lambdax: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(lambdax,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
04
17
210
313
416
519
622
725
828
......
dtype:int32
apply()方法的使用和前两者稍有不同,map()方法和filter()方法我们都需要将可迭代对象放入其中,而这里的apply()则不需要
myseries.apply(lambdax:(x+5)/x**2)
output
00.562500
10.244898
20.150000
30.106509
40.082031
50.066482
60.055785
70.048000
......
dtype:float64
而要是遇到DataFarme表格数据的时候,也是同样地操作
df=pd.read_csv(r'Dummy_Sales_Data_v1.csv')
df["Sales_Manager"]=df["Sales_Manager"].apply(lambdax:x.upper())
df["Sales_Manager"].head()
output
0PABLO
1PABLO
2KRISTEN
3ABDUL
4STELLA
Name:Sales_Manager,dtype:object
apply()方法处理可是比直接用str.upper()方法来处理,速度来的更快哦!!不太适合使用的场景
lambda函数作为一个匿名函数,不适合将其赋值给一个变量,例如下面的这个案例squared_sum=lambdax,y:x**2+y**2
squared_sum(3,4)
相比较而言更好的是自定义一个函数来进行处理
defsquared_sum(x,y):
returnx**2+y**2
squared_sum(3,4)
output
25
而我们遇到如下情景的时候,可以对代码稍作简化处理
importmath
mylist=[10,25,40,49,65,81]
sqrt_list=list(map(lambdax:math.sqrt(x),mylist))
sqrt_list
output
[3.16227766,5.0,6.324555320,7.0,8.062257748,9.0]
我们可以将其简化成
importmath
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函数中,可以直接抽出来用
文章转发自AI科技大本营微信公众号,版权归其所有。文章内容不代表本站立场和任何投资暗示。
Copyright © 2021.Company 元宇宙YITB.COM All rights reserved.元宇宙YITB.COM