一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。
map(fun_name,L)
map()
函数接收两个参数,一个是函数,一个是Iterable
,map
将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator
返回。
例如:
L = [1, 2, 3]
def int_to_str(L):
return map(str, L)
print(list(int_to_str(L)))
输出:[‘1’, ‘2’, ‘3’]
reduce(fun_name,L)
reduce
把一个函数作用在一个序列[x1, x2, x3, ...]
上,这个函数必须接收两个参数,reduce
把结果继续和序列的下一个元素做累积计算,其效果就是:
reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)
例如下面这个字符串转int的函数:
from functools import reduce
DIGITS = {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}
def char2num(s):
return DIGITS[s]
def str2int(s):
return reduce(lambda x, y: x * 10 + y, map(char2num, s))
print(str2int('2'))
输出:2
filter(fun_name,L)
和map()
类似,filter()
也接收一个函数和一个序列。和map()
不同的是,filter()
把传入的函数依次作用于每个元素,然后根据返回值是True
还是False
决定保留还是丢弃该元素
例如删除一个序列中的偶数:
def is_odd(n):
return n % 2 == 1
list(filter(is_odd, [1, 2, 4, 5, 6, 9, 10, 15]))
# 结果: [1, 5, 9, 15]
sorted(L)\sorted(L,key = fun_name)
排序方法,可直接传入序列进行排序,或者传入参数key对序列的每一个方法作函数处理再进行排序
例如英文字符串排序:
print(sorted(['bob', 'about', 'Zoo', 'Credit'], key=str.lower))
由于默认的字符串排序,是按照ascll的大小比较的,加上str.lower函数,可实现忽略大小写的排序
要进行反向排序,不必改动key函数,可以传入第三个参数reverse=True
:
>>> sorted(['bob', 'about', 'Zoo', 'Credit'], key=str.lower, reverse=True)
['Zoo', 'Credit', 'bob', 'about']
匿名函数——lambda
fun = lambda x: x * x
print(fun(5))