时间:2021-05-23
1. 普通装饰器
import logging 1. foo = use_loggine(foo) def use_loggine(func): def wrapper(): logging.warn("%s is running " % func.__name__) return func() return wrapper @use_loggine def foo(): print "aaa" foo() print foo.__name__2. func 需要参数:
foo = use_loggine(foo) 第一个参数就是func这个函数对象,不包含参数foo(params) def use_loggine(func): def wrapper(name): logging.warn("%s is running " % func.__name__) return func(name) return wrapper @use_loggine def foo(name): print "name is %s" % name3. 装饰器带参数
foo = use_logging('warn')(foo) 还是把被装饰的函数当做参数赋给装饰器 def use_logging(level): def decorator(func): def wrapper(*args, **kwargs): if level == 'warn': logging.warn("%s is running" % func.__name__) elif level == 'info': logging.warn("%s is running" % func.__name__) return func(*args) return wrapper return decorator @use_logging('warn') def foo(name): print "i am %s" % name foo = use_logging('warn')(foo) print foo.__name__ foo('foo')4. 类装饰器,还是把被装饰的函数当做参数赋给装饰器
foo = Foo(params)(func) class Foo(object): def __init__(self, name): self.name = name def __call__(self, func): def aa(): print "class decorator running" print "name is :%s" % self.name func() print 'class decorator ending' return aa @Foo("hello") def bar(): print "world" bar() @deco def foo() pass foo = deco(foo) @deco(xx) def foo(): pass foo = deco(xx)(foo)5. 类方法装饰器
类方法装饰器和其他装饰器没有什么区别,只不过在装饰器内部返回的函数中,第一个参数是固定的,是调用方法的对象本身,如
果是实例对象,就是self,是类方法的话,就是cls,静态方法的话,没有第一个参数。
from functools import wraps def method_decor(func): @wraps(func) def wrapper(*args, **kwargs): try: u = func(*args, **kwargs) return u except Exception as e: args[0].bb() # args[0]就是self或者cls。可以在args前面定义self,更加方便u = func(self,*args, **kwargs) return 'an Exception raised.' return wrapper class Foo(object): @method_decor def aa(self): # print("This is wraped method") raise Exception('aa') def bb(self): print("This is called method") a = Foo() a.aa()以上这篇python装饰器相当于函数的调用方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
装饰器这东西我看了一会儿才明白,在函数外面套了一层函数,感觉和java里的aop功能很像;写了2个装饰器日志的例子,第一个是不带参数的装饰器用法示例,功能相当于
复制代码代码如下:functionaddEvent(obj,type,f
Python中有一个有趣的语法,只要定义类型的时候,实现__call__函数,这个类型就成为可调用的。换句话说,我们可以把这个类型的对象当作函数来使用,相当于重
本文实例讲述了Python装饰器原理与基本用法。分享给大家供大家参考,具体如下:装饰器:意义:在不能改变原函数的源代码,和在不改变整个项目中原函数的调用方式的情
Python中的闭包的概念,在我看来,就相当于在某个函数中又定义了一个或多个函数,内层函数定义了具体的实现方式,而外层返回的就是这个实现方式,但并没有执行,除非