文档章节

decorator定义与使用<一>:function decorator

Aomo
 Aomo
发布于 2016/02/05 22:26
字数 488
阅读 29
收藏 1
#!/usr/bin/python3
"""
decorator定义与使用<一>:function decorator

Function decorators are largely just syntactic sugar that runs one function(the decorated one) through 
another(the decorator,a callable object) at the end of a def statement, and rebinds the original function 
name to the result.

Deccorator of a simple function can be either a class with __call__ or a function so long as it returns a callable 
object, at the end of which a result should better be returned no matter whether the decorated function returns anything 
because the original function may return something.

The decorator function is called immediately after the definition of the decorated function, so is the decorator
class initialized.

NOTE: Decorator of a class method can only be a function. If a decorator of a class with __call__ is applied to a class method,
the 'self' argument in the decorated method would never be passed to the __call__(*args) method of the decorator class.

Following comes a simple example.
----------------------------------
def decorator_example(func,*args):
    do something to initialize
    def tmp(*args):
        do any thing you want
        return func(*args)
    return tmp
    
@decorator_example
def():
    pass
    
----------------------------------

"""
class Tracer:
    """
    Tracer是一个类形式的function decorator,用来Trace其他函数的调用。
    @Tracer
    def function_name(...):...
    """
    def __init__(self,func):
        """
        每个被此decorator修饰的函数,在其定义(声明)之后立即执行此init函数.
        参数:func即为被修饰的函数.
        """
        print('Start tracing:',func.__name__)
        self.calls=0
        self.func=func
        
    def __call__(self,*args):
        """
        调用被修饰的函数时,其实是调用此函数.
        args为调用被修饰函数时传入的参数.
        """
        #You can do whatever you want here,before the 'return'
        self.calls+=1
        print("%s calls to %s" % (self.calls,self.func.__name__))
        return self.func(*args)    

def Tracer2(func):
    """
    Tracer2是一个函数形式的function decorator。
    """
    print('decorating %s with Tracer2' % func.__name__)
    def tmp(*args):
        print('Tracer2:'+func.__name__) #You can do whatever you want here,before the 'return'.
        return func(*args)
    return tmp

@Tracer
def foo(a,b,c):
    return a+b+c

#取消下一行注释,即可验证__init__中的注释:decorator的__init__会在每个被修饰的函数定义之后立即执行,为每个函数生成一个对应的decorator    
#print('between foo and foo2')

@Tracer
def foo2(a,b,c):
    return 'foo2 '+a+b+c
@Tracer2    
def foo3(a,b):
    print('%s,%s' % (a,b))
    return 'foo3 '+a+b

if __name__=='__main__':
    print('---decorator_demo.py---')
    ret=foo3('z','x')
    print(ret)


© 著作权归作者所有

共有 人打赏支持
Aomo
粉丝 2
博文 38
码字总数 16740
作品 0
高级程序员
python装饰器(decorator)学习笔记

文章来自stackoverflow上一个问题的答案 Python’s functions are objects To understand decorators, you must first understand that functions are objects in Python. This has importan......

alazyer
2016/08/25
19
0
转载:唐磊的个人博客《python中decorator详解》【转注:深入浅出清晰明了】

转载请注明来源:唐磊的个人博客《python中decorator详解》 前面写python的AOP解决方案时提到了decorator,这篇文章就详细的来整理下python的装饰器——decorator。 python中的函数即objects...

laugh2last
2015/08/17
0
0
Django中六个常用的自定义装饰器

装饰器作用 decorator是当今最流行的设计模式之一,很多使用它的人并不知道它是一种设计模式。这种模式有什么特别之处? 有兴趣可以看看Python Wiki上例子,使用它可以很方便地修改对象行为,...

j_hao104
07/03
0
0
Python高级编程-----读书笔记

Keep Code Simple Not Data l 减少代码,能减少生成的代码,因此能减少执行时间 2. 使用List Comprehensions构造List,快12倍 List Comprehension性能测试 使用List Comprehension使语法简洁...

索隆
2012/05/19
0
0
设计模式 – 装饰模式(Decorator)

问 题的提出:一个人装扮,可以先穿裤子,再穿衣服,再穿鞋子;也可以先穿衣服,再是裤子,再是鞋子,由于裤子、衣服、鞋子种类很多,故搭配种类就更多了。又 如制作蛋糕,鲜奶油蛋糕、草莓蛋...

lovedreamland
2011/02/10
0
0

没有更多内容

加载失败,请刷新页面

加载更多

为什么 vue 默认导出的是 vue.common.js,它和 vue.js 的区别在哪里,又有什么关系?

这个问题在囧克斯的博客中有提到。 Vue 最早会打包生成三个文件,一个是 runtime only 的文件 vue.common.js,一个是 compiler only 的文件 compiler.js,一个是 runtime + compiler 的文件 ...

粒子数反转
13分钟前
0
0
php正则表达式替换图片地址

<?php /*PHP正则提取图片img标记中的任意属性*/ $str = '<center><img src="/uploads/images/20100516000.jpg" height="120" width="120"><br />PHP正则提取或更改图片img标记中的任意属性<......

mdoo
16分钟前
0
0
一个简单的系统监控脚本

一个简单的系统信息监控脚本 #!/bin/bash# DATE:20181018# System monitor by Kxvzinterval=5while :doecho '==========================================================...

Kxvz
19分钟前
0
0
七牛云助你度寒冬 | 每天 10:24, 新用户抢全额免单

近年来,中美贸易战、股市暴跌、房地产变天、人民币贬值等等,企业艰难生存于冰川夹缝之中,融资发展难上加难。 凛冬将至, 七牛云特此推出免单好礼,为新用户(2018 年 10 月 10 日后新注册...

七牛云
20分钟前
0
0
Echarts X轴刻度标签换行显示

xAxis: [ { 'type':'category', splitLine: {show: false}, axisLabel: { show: true,//是否显示 interval:0,//强制显示 ......

郭周园
25分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部