python 把函数作为参数
如果传入abs 作为参数
def add(x,y,y):
return f(x) + f(y)
add(-5,9,abs)
abs(-5) + abs(9)
python 中map() 函数
list的每一个元素上,得到一个新的list 并返回。
我们需要传入函数f(x) = x*x,就可以利用map() 完成计算
def f(x):
return x*x
print map(f,[1,2,3,4,5,6,7,8,9])
输出结果:
[1,10,25,36,49,64,81]
注意:map()函数不改变原有的 list,而是返回一个新的 list。
python reduce() 函数
def f(x,y):
return x+y
reduce(f,9]) 时, reduce 函数做如下计算
先计算头两个元素:f(1,3),结果为4; 再把结果和第3个元素计算:f(4,5),结果为9;
再把结果和第4个元素计算:f(9,7),结果为16; 再把结果和第5个元素计算:f(16,9),结果为25;
由于没有更多的元素了,计算结束,返回结果25。
reduce()还可以接收第3个可选参数,作为计算的初始值。如果把初始值设为100,计算:
reduce(f,9],100)
结果将变为125,因为第一轮计算是:
计算初始值和第一个元素:f(100,1),结果为101。
python 中filter() 函数
返回True 或 False, filter() 根据判断结果自动过滤掉不符合条件的元素,返回
由符合元条件元素组成的一组的新的list
要从一个list [1,12,17]中删除偶数,保留奇数,
要编写一个判断奇数的函数:
def is_odd(x):
return x % 2 == 1
然后利用filter() 过滤掉偶数:
filter(is_odd,17])
结果:[1,17]
sorted() 函数可对list 进行招聘
sorted([36,21])
[5,21,36]
比较的元素 x,y,如果 x 应该排在 y 的前面,返回 -1,如果 x 应该排在 y 的后面,
返回 1。如果 x 和 y 相等,返回 0。
如果我们要实现倒序排序,只需要编写一个reversed_cmp函数:
def reversed_cmp(x,y): if x > y: return -1 if x < y: return 1 return 0
调用 sorted() 并传入 reversed_cmp 就可以实现倒序排序:
sorted([36,21],reversed_cmp)
[36,5]
sorted()也可以对字符串进行排序,字符串默认按照ASCII大小来比
sorted(['bob','about','Zoo','Credit'])
['Credit','bob']
python 中闭包
def f():
print 'f()...'
def g():
print 'g()...'
return g
def calc_sum(lst):
def lazy_sum():
return sum(lst)
return lazy_sum
的情况,称为闭包(Closure)。
python 中匿名函数
map(lambda x: x * x,9])
[1,16,81]
以简化代码:
sorted([1,0],lambda x,y: -cmp(x,y))
[9,1,0]