高阶函数
高阶函数特点:
1.接收一个或多个函数作为参数
2.将函数作为返回值返回的也是一个高阶函数
3.将函数作为参数进行传递,实际上是i将该函数中的方法(代码)进行传递
lst = [1,2,3,4,5,6,7,8,9,10]
def fn2(i):
if i % 2 == 0:
return True
def fn3(i):
if i > 5:
return True
def fn4(k):
if k % 3 == 0:
return True
def fn(func,l):
new_list = []
for n in l:
if func(n):
new_list.append(n)
return new_list
print(fn(fn4,lst))#只需要将参数fn4改成成自己需要的方法即可
总结:根据需要定义不同的函数功能模块,然后根据需要直接将对应的功能函数名称进行传递即可达到要求,相当于将功能函数的代码块进行传递。
匿名函数
匿名函数也就是lambda表达式,专门用来创建一些简单的函数,也是函数的另一种创建方式
语法:lambda 参数列表 :返回值
匿名函数最大的好处:函数只会用一次,用后就释放内存空间
print((lambda a,b:a+b)(1,2))
lambda赋值给一个变量:
fn = lambda a,b:a+b
print(fn(1,2))
lst = [1,2,3,4,5,6,7,8,9,10]
print(list(filter(lambda a:a%3==0,lst)))
filter(函数参数,可迭代对象),返回的结果是list(列表)的形式
lst = [1,2,3,4,5,6,7,8,9,10]
def fn(l):
if l%3==0:
return True
print(list(filter(fn,lst)))
闭包
闭包的条件:函数嵌套、讲内部函数作为返回值返回、定义的参数进行私有化
def make_fn():**#函数嵌套--->要素1**
nums = []**#定义的参数私有化--->要素2**
def fn1(n):
nums.append(n)
return sum(nums)/len(nums)
return fn1**#内部函数返回值--->要素3**
mf = make_fn()
print(mf(10))
print(mf(20))
装饰器
装饰器的作用在不改变原函数的情况下进行扩展
装饰器的特点:
1、如果修改的的函数过多
2、为了方便后期维护
3、符合OPC规则(开闭规则)
例如:在下列函数中增加2个输出
def add(a,b):
r = a+b
return r
在r=a+b前后增加输出
def add(a,b):
r = a+b
return r
def new_fn(a,b):
print('前面的')
r = add(a,b)
print('后面的')
return r
a = new_fn(1,2)
print(a)
上面代码就是在不修改add()函数的基础上进行扩展
def fn():
print('我是原函数')
def add_fn():
print('扩展的第一部分')
fn()
print('扩展的第二部分')
add_fn()
'''
扩展的第一部分
我是原函数
扩展的第二部分
'''
当函数功能特别多的时候就需要装饰器的介入:
def add(a,b):
r = a+b
return r
def mul(i,x):
r = i*x
return r
#装饰器开始
def start_f(old):
def new_f(*args,**kwargs):
r = old(*args,**kwargs)
return r
return new_f
#装饰器结束
f = start_f(mul)
r = f(1,2)
print(r)
def add(a,b):
r = a+b
return r
def mul(i,x):
r = i*x
return r
def start_f(old):
def new_f(*args,**kwargs):
print('扩展一')
r = old(*args,**kwargs)
print('扩展二')
return r
return new_f
f = start_f(mul)
r = f(1,2)
print(r)
@start_f#引用装饰器,建议与要引用的函数挨着写,便于阅读性
def a():
print('教师节')
a()
'''
结果是:
扩展一
教师节
扩展二
'''
注意“@”的使用