博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
lambda表达式&map&filter&yield
阅读量:6679 次
发布时间:2019-06-25

本文共 2957 字,大约阅读时间需要 9 分钟。

 

 

一、先来看下lambda表达式

1、lambda表达式其实很简单,他是简单的函数的变种,只有三部分组成,之前老师没有讲清楚,今天看书,终于明白了,写个博客记录下

lambda关键字+参数+返回值,参数之间用逗号隔开,参数和返回值之间用冒号隔开,表达式结尾最好用分号隔开;

我们看下下面的例子

f = lambda x,y,z:x * y * zprint(f(2,3,4))

  

lambda关键字,x,y,z是三个参数,表达式 x * y * z就是在函数中的returen中的表达式,我们可以通过f来调用这个lambda表达式,通过传递指定参数,然后拿到表达式的结果

结果如下

 

 2、表达式其实主要使用的场景是在列表或者字典中,看下下面的例子

l = [    lambda x:x ** 2,    lambda x:x ** 3,    lambda x:x ** 4,]for f in l:    print(f(100))print(l[0](100))

  

结果如下

 

 

 3、lambda也可以传递默认参数,我们看下下面的例子

f = lambda x,y=2,z=3:x + y + zprint(f(1,4,5))print(f(2,4))print(f(2))

  

结果如下

 

 

4、lambda还可以实现简单的if-else语句

f = lambda x,y:"aaa" if x > y else "bb";print(f(2,4))#如果x大于y,则返回“aaa”,如果x不大于y,则返回“bbb”

  

结果如下

 

 5、还可以在一个函数中定义一个lambda,这个lambda还可以运用函数中的局部变量

import sysdef test(x):    sys.stdout.write("hahh" + "\n")    #sys.stdout.write( == print    return lambda y:x * yf = test(2)# 这里这个f是lambda表达式的地址sys.stdout.write(str(f(3)))#这个lambda可以直接使用函数中的局部变量x

  

结果如下

 

二、在来介绍一下map这个内置函数

map这个内置的作用就是:对一个或者多个可迭代的对象,比如列表,元组,遍历每一个元素,然后将每个元素作为参数传递到map的第一个参数中,这个参数一定是一个函数的地址,然后返回一个可迭代的对象,这个对象必须要用list才能打印出来,我们看下面的例子

f = lambda x:x + 100print(map(f,[1,2,3,4,5,6,7,8,9]))# 这里是返回这个对象的地址print(list(map(f,[1,2,3,4,5,6,7,8,9])))#通过list方法才能拿到这个可迭代对象的内容

  

结果如下

 

map内置函数不仅仅可以传递一个可迭代的对象,还可以传递多个可迭代的对象,他首先从第一个对象中取第一个值,然后从第二个对象中取第一个值,依次类推

f = lambda x,y: x + y + 100;print(list(map(f,[1,2,3,4,5,6,7,8,9],[1,2,3,4,5,6,7,8,9])))

  

结果如下

 

 

 三、最后在来介绍下filter函数

filter函数的作用将可迭代对象中的每个元素传递到filter的第一个参数中,这个参数一定是一个函数,然后将执行结果为true的返回到可迭代的对象中,执行结果为false的直接丢失,也就是被过滤掉了

f = lambda x:True if x > 5 else False;print(list(filter(f,[1,2,3,4,5,6,7,8,9])))

  

结果如下

上面的例子还可以简写成这样

f = lambda x:x > 5;print(list(filter(f,[1,2,3,4,5,6,7,8,9])))

  

结果如下

 

 

最后一点版面在稍微复习一下生成器

def gen(x):    for i in range(x):        temp = yield i ** 3        print(temp)g = gen(5)a = next(g)print(a)a = next(g)print(a)

  

a、执行g = gen(5),生成了一个生成器

b、然后在a = next(g),这里这个a是什么呢?因为next方法执行yield就终止了,不继续往下执行,而yield后面的表达式的值就相当于普通函数的return,所以a的值就相当于yield后面表达式的值,这里也就是“0”,执行到这里后,就从函数中跳出来,因为遇到yield了,所以就需要跳出函数,执行外面的语句

c、第三步就开始执行print(a)语句,因为a 就相当于函数的返回值,也就是yield后面表达式返回的值,所以这里是0

d、执行完print(a)语句后,我们的第四步就是再次使用next方法进入生成器,这个时候,生成器函数是从上次跳出函数的位置开始执行,也就是print(temp),而这个temp是什么呢?temp不是yield后面返回的,temp的值只能通过外部生成器对象调用send方法进行传递,这里我们没有在外部通过生成器对象调用send方法传递,所以这里的值默认情况下是none

 

我们在看下面这个例子,这里就有外部调用生成器对象是一共send方法

def gen(x):    for i in range(x):        temp = yield i ** 3        print(temp)g = gen(5)a = next(g)print(a)g.send("xxxx")a = next(g)print(a)

  

a、执行g = gen(5)语句,生成一个生成器对象,这个对象就是g

b、然后在a = next(g),这里这个a是什么呢?因为next方法执行yield就终止了,不继续往下执行,而yield后面的表达式的值就相当于普通函数的return,所以a的值就相当于yield后面表达式的值,这里也就是“0”,执行到这里后,就从函数中跳出来,因为遇到yield了,所以就需要跳出函数,执行外面的语句

c、第三步就开始执行print(a)语句,因为a 就相当于函数的返回值,也就是yield后面表达式返回的值,所以这里是0

d、第四步很关键,我们这里使用生成器对象g调用send方法g.send("xxxx"),这个方法就会传递“xxxx”这个字符串给yield前面的变量,也就是temp这个变量会被赋值为“xxxx”,因为生成器上次是print(temp)语句退出的,通过send方法也可以进行生成器内部,所以第四步这里首先会执行print(temp)语句,这里就会打印"xxxx"

e、打印完xxx后就会继续执行a = next(g)语句,这里就和上一个例子的效果是一样的

 

转载于:https://www.cnblogs.com/bainianminguo/p/8537757.html

你可能感兴趣的文章
python 时间格式转化成毫秒
查看>>
java一些需要掌握的知识点
查看>>
CentOS 6.2 yum安装配置lnmp服务器(Nginx+PHP+MySQL)
查看>>
Redis学习手册 比较全面
查看>>
SpringLDAP-Reference (中文文档四)
查看>>
JQuery上传插件Uploadify使用详解
查看>>
(二)线程同步_6---修改锁的竞争原则
查看>>
Intent跳转时,activity的生命周期
查看>>
Java基础数据结构和堆栈
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
ubuntu建立和删除用户
查看>>
Html5本地图片读取及裁剪
查看>>
MySQL数据库操作个人手记
查看>>
我的友情链接
查看>>
泡沫学员CSS切图学习总结
查看>>
centos 学习日记 文件隐藏属性 chattr lsattr
查看>>
redhat yum 失败
查看>>
log4j2日志框架使用简单概述
查看>>
新手处理事故之误删boot目录以及更严重的删除操作
查看>>