-
高阶函数
map\reducedef f(x): return x * x #map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果 #作为新的Iterator返回。 r = map(f,[1,2,3,4,5]) #Iterator是惰性序列,因此通过list()函数让它把整个序列都计算出来并返回一个list。 list(r) def add(x,y): return x + y #reduce把一个函数作用在一个序列上,这个函数必须接收两个参数, #reduce把结果继续和序列的下一个元素做累积计算 reduce(add,[1,2,3,4])#
filter
Python内建的filter()函数用于过滤序列
和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
Python内置的sorted()的函数可以对list进行排序sorted([-21,-12,5,9,36])
sorted()函数也是一个高阶函数,它还可以接收一个key函数来实现自定义的排序,例如按绝对值大小排序
sorted([36, 5, -12, 9, -21], key=abs) sorted([36, 5, -12, 9, -21], key=str.lower) sorted([36, 5, -12, 9, -21], key=abs,reverse=True)#第三个参数为True进行反向排序
-
返回函数
将函数作为返回值,返回的不是函数的运行结果而是函数 -
匿名函数
利用lambda关键字定义匿名函数lambda x:x*x #关键字lambda表示匿名函数,冒号前面的x不是函数名,而是参数 #lamdba有个限制,就是只能有一个表达式,不能写return,返回值就是该表达式的结果
Python学习笔记-python基础05-函数式编程
最新推荐文章于 2024-04-04 15:39:34 发布