一,lambda 函数也叫匿名函数,即,函数没有具体的名称.先来看一个最简单例子:
def f(x):
return x**2
print f(4)
Python 中使用 lambda 的话,写成这样
g = lambda x : x**2
print g(4)
二,lambda 和普通的函数相比,就是省去了函数名称而已,同时这样的匿名函数,又不能共享在别的地方调用.
其实说的没错,lambda 在 Python 这种动态的语言中确实没有起到什么惊天动地的作用,因为有很多别的方法能够代替 lambda.
1. 使用 Python 写一些执行脚本时,使用 lambda 可以省去定义函数的过程,让代码更加精简.
2. 对于一些抽象的,不会别的地方再复用的函数,有时候给函数起个名字也是个难题,使用 lambda 不需要考虑命名的问题.
3. 使用 lambda 在某些时候让代码更容易理解.
lambda 基础
lambda 语句中,冒号前是参数,可以有多个,用逗号隔开,冒号右边的返回值.lambda 语句构建的其实是一个函数对象,见证一下:
>>> foo = [2, 18, 9, 22, 17, 24, 8, 12, 27]
>>> print filter(lambda x: x % 3 == 0, foo)
[18, 9, 24, 12, 27]
>>> print map(lambda x: x * 2 + 10, foo)
[14, 46, 28, 54, 44, 58, 26, 34, 64]
>>> print reduce(lambda x, y: x + y, foo)
139
在对象遍历处理方面,其实 Python 的 for..in..if 语法已经很强大,并且在易读上胜过了 lambda.
以 Mark Lutz 著的《Python 学习手册》为教程,每天花 1 个小时左右时间学习,争取两周完成. --- 写在前面的话
2013-7-22 21:00 学习笔记
1,lambda 的一般形式是关键字 lambda 后面跟一个或多个参数,紧跟一个冒号,以后是一个表达式.lambda 是一个表达式而不是一个语句.它能够出现在 Python 语法不允许 def 出现的地方.作为表达式,lambda 返回一个值(即一个新的函数).lambda 用来编写简单的函数,而 def 用来处理更强大的任务.
[python] view plain
copy
f = lambda x,y,z : x+y+z
print f(1,2,3)
g = lambda x,y=2,z=3 : x+y+z
print g(1,z=4,y=5)
输出结果为:
[python] view plain
copy
6
10
2,lambda 表达式常用来编写跳转表(jump table),就是行为的列表或字典.例如:
[python] view plain
copy
L = [(lambda x: x**2),
(lambda x: x**3),
(lambda x: x**4)]
print L[0](2),L[1](2),L[2](2)
D = {'f1':(lambda: 2+3),
'f2':(lambda: 2*3),
'f3':(lambda: 2**3)}
print D['f1'](),D['f2'](),D['f3']()
输出结果为:
[python] view plain
copy
4 8 16
5 6 8
3,lambda 表达式可以嵌套使用,但是从可读性的角度来说,应尽量避免使用嵌套的 lambda 表达式.
4,map 函数可以在序列中映射函数进行操作.例如:
[python] view plain
copy
def inc(x):
return x+10
L = [1,2,3,4]
print map(inc,L)
print map((lambda x: x+10),L)
输出结果为:
[python] view plain
copy
[11, 12, 13, 14]
[11, 12, 13, 14]
5,列表解析可以实现 map 函数同样的功能,而且往往比 map 要快.例如:
[python] view plain
copy
print [x**2 for x in range(10)]
print map((lambda x: x**2), range(10))
输出结果为:
[python] view plain
copy
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
6,列表解析比 map 更强大.例如:
[python] view plain
copy
print [x+y for x in range(5) if x%2 == 0 for y in range(10) if y%2 ==1]
输出结果为:
[python] view plain
copy
[1, 3, 5, 7, 9, 3, 5, 7, 9, 11, 5, 7, 9, 11, 13]
7,生成器函数就像一般的函数,但它们被用作实现迭代协议,因此生成器函数只能在迭代语境中出现.例如:
[python] view plain
copy
def gensquares(N):
for i in range(N):
yield i**2
for i in gensquares(5):
print i,
输出结果为:
[python] view plain
copy
0 1 4 9 16
8,所有的迭代内容(包括 for 循环,map 调用,列表解析等等)将会自动调用 iter 函数,来看看是不是支持了迭代协议.
9,生成器表达式就像列表解析一样,但它们是扩在圆括号 () 中而不是方括号 [] 中.例如:
[python] view plain
copy
for num in (x**2 for x in range(5)):
print num,
输出结果为:
[python] view plain
copy
0 1 4 9 16
10,列表解析比 for 循环具有更好的性能.尽管如此,在编写 Python 代码时,性能不应该是最优先考虑的.
11,没有 return 语句时,函数将返回 None 对象.
12,函数设计的概念:
耦合性:只有在真正必要的情况下才使用全局变量
耦合性:不要改变可变类型的参数,除非调用者希望这样做
耦合性:避免直接改变另一个文件模块中的变量
聚合性:每一个函数都应有一个单一的,统一的目标
13,最后给个默认参数和可变参数的例子:
[python] view plain
copy
def saver(x=[]):
x.append(1)
print x
saver([2])
saver()
saver()
saver()
输出结果为:
[python] view plain
copy
[2, 1]
[1]
[1, 1]
[1, 1, 1]
来源: http://www.bubuko.com/infodetail-2472403.html