lambda表达式&map&filter&yield详解编程语言

 

 

一、先来看下lambda表达式

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

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

我们看下下面的例子

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

  

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

结果如下

lambda表达式&map&filter&yield详解编程语言

 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)) 

  

结果如下

lambda表达式&map&filter&yield详解编程语言

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

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

  

结果如下

lambda表达式&map&filter&yield详解编程语言

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

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

  

结果如下

lambda表达式&map&filter&yield详解编程语言

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

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

  

结果如下

lambda表达式&map&filter&yield详解编程语言

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

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

f = lambda x:x + 100 
 
print(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方法才能拿到这个可迭代对象的内容 

  

结果如下

lambda表达式&map&filter&yield详解编程语言

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]))) 

  

结果如下

lambda表达式&map&filter&yield详解编程语言

 三、最后在来介绍下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]))) 

  

结果如下

lambda表达式&map&filter&yield详解编程语言

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

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

  

结果如下

lambda表达式&map&filter&yield详解编程语言

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

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)语句,这里就和上一个例子的效果是一样的

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/20839.html

(0)
上一篇 2021年7月19日
下一篇 2021年7月19日

相关推荐

发表回复

登录后才能评论