Python @函数装饰器

2020-09-08  本文已影响0人  手捧樱花v

无参数的@函数装饰器

#funA 作为装饰器函数
def funA(fn):
    print("sakura_func_A")
    fn() # 执行传入的fn参数
    print("sakura_second")
    return "sakura return"
@funA
def funB():
    print("sakuraB")

返回结果为

sakura_func_A
sakuraB
sakura_second

如果直接Print(funB),其结果为

sakura return

被“@函数”修饰的函数不再是原来的函数,而是被替换成一个新的东西(取决于装饰器的返回值),实际上,所谓函数装饰器,就是通过装饰器函数,在不修改原函数的前提下,来对函数的功能进行合理的扩充。

带参数的@函数装饰器
比较简单的解决方法就是在函数装饰器中嵌套一个函数,该函数带有的参数个数和被装饰器修饰的函数相同

def funA(fn):
    # 定义一个嵌套函数
    def say(arc):
        print("Python教程:",arc)
    return say
@funA
def funB(arc):
    print("funB():", a)
funB("http://c.biancheng.net/python")

如果当前程序中,有多个(≥ 2)函数被同一个装饰器函数修饰,这些函数带有的参数个数并不相等,最简单的解决方式是用 * args 和 ** kwargs 作为装饰器内部嵌套函数的参数,*args 和 **kwargs 表示接受任意数量和类型的参数

def funA(fn):
    # 定义一个嵌套函数
    def say(*args,**kwargs):
        fn(*args,**kwargs)
    return say
@funA
def funB(arc):
    print("C语言中文网:",arc)
@funA
def other_funB(name,arc):
    print(name,arc)
funB("http://c.biancheng.net")
other_funB("Python教程:","http://c.biancheng.net/python")

嵌套装饰器

@funA
@funB
@funC
def fun():
    #...

执行顺序

fun = funA( funB ( funC (fun) ) )
上一篇 下一篇

猜你喜欢

热点阅读