码迷,mamicode.com
首页 > 其他好文 > 详细

装饰器进阶

时间:2018-02-05 21:50:09      阅读:205      评论:0      收藏:0      [点我收藏+]

标签:9.png   导入模块   info   技术分享   聚合   turn   wrap   blog   inf   

1. 开放封闭原则

1.对扩展是开放的

    为什么要对扩展开放呢?

    我们说,任何一个程序,不可能在设计之初就已经想好了所有的功能并且未来不做任何更新和修改。所以我们必须允许代码扩展、添加新功能。

  2.对修改是封闭的

    为什么要对修改封闭呢?

    就像我们刚刚提到的,因为我们写的一个函数,很有可能已经交付给其他人使用了,如果这个时候我们对其进行了修改,很有可能影响其他已经在使用该函数的用户。

装饰器完美的遵循了这个开放封闭原则

2.函数中有用信息

导入模块from functools import wraps

print(f1.__doc__) 获取函数说明信息
print(f1.__name__) 获取函数名

def func(*args):
    ‘‘‘
    计算两个数的和
    :return:
    ‘‘‘
    sum=args[0]+args[1]
    return sum
func(15,17)
print(func.__doc__)      # 计算两个数的和     :return:
print(func.__name__)     #func

结果:

技术分享图片

在装饰器中要显示需要添加模块   @wraps(func) #加在最内层函数正上方

from functools import wraps
def wrapper(func):
    @wraps(func)     ##加在最内层函数正上方
    def inner(*args,**kwargs):
        "输出一个数"
        ret=func(*args,**kwargs)
        return ret
    return inner
@wrapper
def func():
    "输出666"
    print(666)
func()
print(func.__doc__)      #输出666
print(func.__name__)     #func

结果:

技术分享图片

3. *args **kwargs

*args  **kwargs在执行函数中时是打散,在定义函数,接收时聚合,聚合成元祖.
def func(*args):
    print(args,type(args))    #1 2 3
    print(args,type(args))   #(1, 2, 3) <class ‘tuple‘>
func(*[1,2,3])

结果:

技术分享图片

  4 .装饰器进阶

flag = True
def wrapper_out(flag):
    def wrapper(func):
        def inner(*args,**kwargs):
            ‘‘‘执行函数前‘‘‘
            if flag:
                ret = func(*args,**kwargs)
                ‘‘‘执行函数后‘‘‘
                print(222)
                return ret
            else:
                ret = func()
                return ret
        return inner
    return wrapper

@wrapper_out(flag)     #第一步是调用 wrapper_out(flag),接收到返回值wrapper
def func():           #第二步是@wrapper,即func = wrapper(func)
    print(111)
func()

结果:

技术分享图片

  2.多个装饰器装饰一个函数

 

def wrapper1(func):  # func = f
def inner1():
print(‘wrapper1 ,before func‘)
func()
print(‘wrapper1 ,after func‘)
return inner1

def wrapper2(func): # func = inner1
def inner2():
print(‘wrapper2 ,before func‘)
func()
print(‘wrapper2 ,after func‘)
return inner2

@wrapper2 # f = wrapper2(f) 里面的f == inner1 外面的f = inner2
@wrapper1 # f = wrapper1(f) 返回inner1 f = inner1
def f():
print(‘in f‘)
f() # inner2()

结果:

技术分享图片

 

装饰器进阶

标签:9.png   导入模块   info   技术分享   聚合   turn   wrap   blog   inf   

原文地址:https://www.cnblogs.com/wzbk/p/8419211.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!