day 15 装饰器

2020-01-22 22:18:34 浏览数 (1)

装饰器(重点,难点)

开闭原则: 

           对功能的扩展开放

           对代码的修改是封闭的

在目标函数前和后插入一段新的代码.不改变原来的代码

通用装饰器写法:

# 存在的意义: 在不破坏原有函数调用的基础上,给韩式添加新的功能

        def wrapper(fn):   # fn是目标函数

            def inner(*args, **kwargs): # 聚合, 为了目标函数的传参

                ''''在目标函数之前....''''

                ret = fn(*arg, **kwargs) # 打散, 调用目标函数,ret是目标韩式的返回值

                ''''在目标函数之后....'''

                return ret    #把目标函数返回值返回.保证函数正常的结束

            return inner

       

 @wrapper   ###  func = wrapper(func)  == @wrapper

        def func():

            pass

####  func = wrapper(func)    #此时fn就是func

        func()    #此时执行的是inner

举例造人

def wrapper(fn):

    def inner():

        print('浇水')

        fn()

        print('睡一觉')

    return inner

def zaoren():

    print('捏个泥人')

    print('吹口仙气')

    print('你就出来了')

zaoren = wrapper(zaoren)

zaoren()

同一个函数被多个装饰器装饰

   @wrapper1

        @wrapper2

        @wrapper3

        def func():

            pass

       1  2  3  func 3  2  1

def wrapper1(fn):

    def inner(*args, **kwargs):

        print("1111111")

        ret = fn(*args, **kwargs)

        print("2222222")

        return ret

    return inner

def wrapper2(fn):

    def inner(*args, **kwargs):

        print("3333333")

        ret = fn(*args, **kwargs)

        print("44444444")

        return ret

    return inner

def wrapper3(fn):

    def inner(*args, **kwargs):

        print("555555")

        ret = fn(*args, **kwargs)

        print("666666")

        return ret

    return inner

# 就近原则

@wrapper1

@wrapper2

@wrapper3

def func():

    print("我是可怜的func")

func()

# 1 2 3  func 3 2 1

##1111111

3333333

555555

我是可怜的func

666666

44444444

2222222

带参数的装饰器(难受)

        def wrapper_out(参数):

            def wrapper(fn):

                def inner(*args, **kwargs): # 聚合

                    在目标函数之前

                    ret = fn(*arg, **kwargs) # 打散

                    在目标函数之后

                    return ret

                return inner

            return wrapper

        

@wrapper_out(实参)  # 执行的时候. 先执行函数的调用然后使用返回值和前面的@组合成装饰器语法糖

        def func():

            pass

    eval  =>  文件操作

    装饰器

    函数

开始举例

def wrapper(fn):

    def inner(*args, **kwargs):

        print('问问金老板,行情怎么样啊')

        ret = fn(*args, **kwargs)

        print('金老板骗我,恨你')

        return ret

    return inner

def yue():

    print('走啊,约不?')

yue = wrapper(yue)

yue()

进行判断

def wrapper_out(flag): # 装饰器本身的参数

    def wrapper(fn): # 目标函数

        def inner(*args, **kwargs): # 目标函数执行需要的参数

            if flag == True:

                print("问问金老板. 行情怎么样啊")

                ret = fn(*args, **kwargs) # 在执行目标函数之前

                print("金老板骗我. 恨你")

                return ret

            else:

                ret = fn(*args, **kwargs)  # 在执行目标函数之前

                return ret

        return inner

    return wrapper

# 语法糖 @装饰器

@wrapper_out(True) # 先执行wrapper_out(True) 返回一个装饰器   再和@拼接  @装饰器

def yue(): # 被 wrapper装饰

    print("走啊. 约不?")

yue()

0 人点赞