Python之lambda表达式和内置函数

lambda表达式其实就是简化的函数表达式。

它只用于处理简单逻辑,

它会自动return数据


通常定义一个函数,按照以下形式:

1
2
3
4
5
def  func(arg):
      return arg +1
result = func(100)
print result
101


以上函数用lambda表达式可以这么写:

1
2
3
func2 = lambda a: a+1
result = func2(100)
print result


在lambda表达式中,func2 相当于函数表达式中的func,即函数的名称

a相当于函数表达式中的arg,即函数的参数。

冒号后面的a+1,相当于函数表达式中的返回结果,只不过在lambda表达式中不再用return来声明了。


之前的文档中介绍过,函数可以添加多个参数,,lambda表达式也可以


例如:

1
2
3
4
func3 = lambda a,b: a + b
result = func3(100,200)
print result
300



Python内置函数


map方法:

map方法会遍历整个序列(包括列表和元组),并对每一个元素进行相应的操作。

例如:有一个列表,将列表中的每一个元素加10。可以用map函数操作

li = [,,]
func1(arg):
    arg +  = (func1,li)

map内部原理其实是,

 = []
I li:
    .append(func1(I))


map函数可以接受多个序列作为参数:

l1 = [,,]
l2 = [,,]
l3 = [,,]
func2(a1,a2,a3):
    a1 + a2 + a3

(func2,l1,l2,l3)

[17, 30, 43]

注意,如果接受多个序列作为参数,则每一个序列的元素个数必须相等。

上面的例子用lambda表达式,这样写

1
2
3
l1 = [,,]
l2 = [,,]
l3 = [,,]

print map(lambda a1,a2,a3:a1+a2+a3,l1,l2,l3)



filter函数:

filter会遍历序列中的每一个元素,按条件对元素进行过滤,其实内部原理就是按照条件进行计算,计算结果为True的元素不过滤,计算结果为False,则过过滤

例如:

例1:

1
2
3
>>> li = [11,22,'',False,0]
>>> print filter(None,li)
[11, 22]

上面的例子中,None表示过滤掉布尔值为假的元素。0,False,空字符串都是布尔值都是假

 = [,,,]
func(a):
    a>(func,)

[44,55]

这里就是遍历l1这个列表,每一个元素通过函数func计算,大于33的则返回True,否则返回False。返回False则被过滤掉了。


reduce函数:

 接受一个序列,遍历序列中的元素,然后进行一系列的计算,得到一个结果。

reduce是将给出的元素按照方法进行计算,至少要接受两个元素。

例如计算1+2+3+4+5的和

reduce的原理是:计算1+2得到a 然后计算a+3,得到b,再计算b+4.依次类推

li =[,,,,]

 = (arg1,arg2:arg1+arg2,li)










本文转自 曾哥最爱 51CTO博客,原文链接:http://blog.51cto.com/zengestudy/1826950,如需转载请自行联系原作者
上一篇:Android 学习之drawerlayout写侧滑菜单


下一篇:Confluence 6 数据库表-授权(Authentication)