python 高阶函数:Decorator(装饰器)
admin
2023-07-24 01:01:49
0

装饰器:原函数基础 ------> 动态添加功能


一、不带参数的decorator

#decorator封装

def log(func):
    def wrapper(*args, **kw):
        print 'call %s():' %func.__name__
        return func(*args, **kw)
    return wrapper


#此函数一定要放在 def log(func): 之后

@log   
def now():
    print "haha"

   
now()

python 高阶函数:Decorator(装饰器)


log(now())
python 高阶函数:Decorator(装饰器)


print "now_name:%s"%now.__name__

python 高阶函数:Decorator(装饰器)


简单的图解:(待以后深入理解后再详细补)

python 高阶函数:Decorator(装饰器)


二、带参数的docurator

#!/usr/bin/python

#docurator封装

def log(text):
    def decorator(func):
        def wrapper(*args, **kw):
            print('%s %s():' % (text, func.__name__))
            return func(*args, **kw)
        return wrapper
    return decorator


@log('execute')
def now():
    print "haha"    


print "now_name:%s"%now.__name__ 

python 高阶函数:Decorator(装饰器)


now()

python 高阶函数:Decorator(装饰器)


print log('execute')
print log(now)
print log('execute')(now)

python 高阶函数:Decorator(装饰器)


三、完整的decorator的写法:Python内置的functools.wraps  

import functools  #导入functools模块

def log(text):
    def decorator(func):
        @functools.wraps(func)
        def wrapper(*args, **kw):
            print('%s %s():' % (text, func.__name__))
            return func(*args, **kw)
        return wrapper
    return decorator

@log('execute')
def now():
    print "haha"
   
print "now_name:%s"%now.__name__  

python 高阶函数:Decorator(装饰器)

now()

python 高阶函数:Decorator(装饰器)

print log('execute')
print log(now)
print log('execute')(now)

python 高阶函数:Decorator(装饰器)



--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

日期:2018/8/18

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

补充:

  1. 多个装饰器的执行顺序是无序的,但执行过程是有序的。

  2. 装饰器执行过程是:遇到外接函数就跳转到另一个装饰器中执行,若再另一个装饰器中遇到同样的外接函数,则继续执行


证明1:多个装饰器的执行顺序是无序的

#!/usr/bin/python
# -*- coding: utf-8 -*-

import time


def extend(func):
    def wrapper(*args, **kwargs):
        print "Begin AAAAAA"
        func(*args, **kwargs)
        print("A:%s"%(func.__name__))
        print(reduce(lambda x,y:x+y, args), kwargs)
        print "End AAAAA"
    return wrapper


def extend1(func):
    def wrapper(*args, **kwargs):
        print "Begin BBBBB"
        func(*args, **kwargs)
        print("B:%s"%(func.__name__))
        print(map(lambda x:x*2, args), kwargs)
        print "End BBBBB"    
    return wrapper

@extend      
@extend1
def get_time1(*args,**kwargs):
    begin_time = time.time()
    for n in range(3,4):
        time.sleep(1)
    end_time = time.time()
    print("run %d "% (end_time - begin_time))
    #print(reduce(lambda x,y:x+y, args), kwargs)

    
if __name__ == "__main__":

    get_time1(1,2,3,4,5,6,ma=1,du=2)

执行结果:先从第一个装饰器标志@extend开始

Begin AAAAAA
Begin BBBBB
run 1 
B:get_time1
([2, 4, 6, 8, 10, 12], {'du': 2, 'ma': 1})
End BBBBB
A:wrapper
(21, {'du': 2, 'ma': 1})
End AAAAA


另一个例子:

#!/usr/bin/python
# -*- coding: utf-8 -*-
def dec1(func):  
    print("1111")  
    def wrapper(*args, **kwargs):  
        print("2222")  
        func()  
        print("3333")  
    return wrapper  

def dec2(func):  
    print("aaaa")  
    def wrapper(*args, **kwargs):  
        print("bbbb")  
        func()  
        print("cccc")  
    return wrapper  

@dec1  
@dec2  
def test():  
    print("test test")  

test()

运行结果:从第二个装饰器标志@dec2开始

aaaa
1111
2222
bbbb
test test
cccc
3333


通过比较,多个解释器的执行顺序是无序的。若大家觉得证明不够严谨,可自己多添几个试试。


证明2:装饰器的执行过程是有序的

图1:

python 高阶函数:Decorator(装饰器)


图2:

python 高阶函数:Decorator(装饰器)




没看懂?没关系,进行步骤解析:

python 高阶函数:Decorator(装饰器)



-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

2018/8/20

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

补充:一个讲的很好的BLOG:  https://blog.csdn.net/xiangxianghehe/article/details/77170585


相关内容

热门资讯

2026中国移动“牵手计划”全... 6月25日,在2026上海世界移动通信大会期间,中国移动成功举办“牵手计划”(hi-H Progra...
厦钨新能获得实用新型专利授权:... 证券之星消息,根据天眼查APP数据显示厦钨新能(688778)新获得一项实用新型专利授权,专利名为“...
2026年大学生AI影像旗舰手... OPPO数码全家桶 随着2026年高考结束,准大学生们即将开启新的人生篇章,一款功能强大、体验出色的...
原创 为... 文昌航天发射场的301号工位上,一道烈焰划破长空。 2月11日11时00分,长征十号运载火箭点火升空...
共筑健康驿站新生态 第六届星辰... 2026年6月15日至18日,第六届医药流通贸易大会暨第六届医药零售业大会(简称“第六届星辰会”)在...
一个智谱,相当于半个阿里巴巴? “年亏损47亿的智谱,市值跻身万亿港元阵营。 “这个估值能睡得着觉吗?”对于智谱的市值,不少市场人士...
原创 小... 小米新机量越来越多,比如小米17T系列、REDMI K90至尊版等,可谓是新机连连。其中小米17全系...
紫光同芯联合中国联通首发eSI... IT之家 6 月 25 日消息,新紫光集团宣布,旗下产业公司紫光同芯在 MWC 上海联合中国联通,首...
“5G+工业互联网”赋能千行百... 央视网消息:工业和信息化部24日联合国务院国资委等五部门共同启动工业5G独立专网试点,此次工业5G独...
谷歌再失AI人才,两名Gemi... 6 月 25 日消息,据彭博社消息,顶尖人工智能研究员乔纳斯 · 阿德勒(Jonas Adler)与...