Python常用基础语法知识点大全(python中基本语法)
268
2022-08-23
二十四种场景全方位解读Python装饰器的用法(python装饰器的应用场景)
文章目录
一、 装饰器是函数
1.1 被装饰对象也是函数
1.1.1 装饰器无参数,被装饰对象无参数1.1.2 装饰器无参数,被装饰对象有参数1.1.3 装饰器有参数,被装饰对象无参数1.1.4 装饰器有参数,被装饰器对象有参数
1.2 被装饰器对象是类
1.2.1 装饰器无参数,被装饰类无参数1.2.2 装饰器无参数,被装饰类有参数1.2.3 装饰器有参数,被装饰类无参数1.2.4 装饰器有参数,被装饰类有参数
1.3 被装饰对象是类中的方法
1.3.1 装饰器无参数,被装饰类中的方法无参数1.3.2 装饰器无参数,被装饰类中的方法有参数1.3.3 装饰器有参数,被装饰类中的方法无参数1.2.4 装饰器有参数,被装饰类中的方法有参数
二、 装饰器是类
2.1 被装饰对象是函数
2.1.1 装饰器无参数,被装饰对象无参数2.1.2 装饰器无参数,被装饰对象有参数2.1.3 装饰器有参数,被装饰对象无参数2.1.4 装饰器有参数,被装饰器对象有参数
2.2 被装饰器对象是类
2.2.1 装饰器无参数,被装饰类无参数2.2.2 装饰器无参数,被装饰类有参数2.2.3 装饰器有参数,被装饰类无参数2.2.4 装饰器有参数,被装饰类有参数
2.3 被装饰对象是类中的方法
2.3.1 装饰器无参数,被装饰类中的方法无参数2.3.2 装饰器无参数,被装饰类中的方法有参数2.3.3 装饰器有参数,被装饰类中的方法无参数2.3.4 装饰器有参数,被装饰类中的方法有参数
一、 装饰器是函数
1.1 被装饰对象也是函数
装饰器是函数,被装饰对象是函数时,此时装饰器的作用是给被装饰对象的函数做功能增强功能,思想是面向切面编程思想,即在被装饰对象的函数的之前和之后做一些额外处理,而不破坏被装饰函数原有的功能实现,主要有以下几种情况:
1.1.1 装饰器无参数,被装饰对象无参数
def decorator(func): def _decorator(): print("before func......") func() print("after func......") return _decorator@decoratordef func(): print("in func()......")if __name__=="__main__": func()
执行结果为:
before func......in func()......after func......
1.1.2 装饰器无参数,被装饰对象有参数
def decorator(func): def _decorator(*args,**kwargs): print("before {name}......".format(name=func.__name__)) func(*args,**kwargs) print("after {name}......".format(name=func.__name__)) return _decorator@decoratordef func1(): print("in func1()......")@decoratordef func2(a,b): print("in func2()......") print("a={a},b={b}".format(a=a,b=b))@decoratordef func3(a,b,c=10): print("in func3()......") print("a={a},b={b}".format(a=a, b=b)) print("c={c}".format(c=c))if __name__=="__main__": func1() func2(1,2) func3(1,2,c=100)
运行结果为:
before func1......in func1()......after func1......before func2......in func2()......a=1,b=2after func2......before func3......in func3()......a=1,b=2c=100after func3......
1.1.3 装饰器有参数,被装饰对象无参数
def wrapper(name): def decorator(func): def _decorator(): print("before {name} ,decorator param is {param}".format(name=func.__name__,param=name)) print("before {name}......".format(name=func.__name__)) func() print("after {name}......".format(name=func.__name__)) return _decorator return decorator@wrapper(name="hello world")def func1(): print("in func1()......")if __name__=="__main__": func1()
运行结果为:
before func1 ,decorator param is hello worldbefore func1......in func1()......after func1......
1.1.4 装饰器有参数,被装饰器对象有参数
def wrapper(name): def decorator(func): def _decorator(*args,**kwargs): print("before {name} ,decorator param is {param}".format(name=func.__name__,param=name)) print("before {name}......".format(name=func.__name__)) func(*args,**kwargs) print("after {name}......".format(name=func.__name__)) return _decorator return decorator@wrapper(name="hello world")def func1(): print("in func1()......")@wrapper(name="hello world")def func2(a, b): print("in func2()......") print("a={a},b={b}".format(a=a, b=b))@wrapper(name="hello world")def func3(a, b, c=10): print("in func3()......") print("a={a},b={b}".format(a=a, b=b)) print("c={c}".format(c=c))if __name__=="__main__": func1() func2(1,2) func3(1,2,c=100)
运行结果如下:
before func1 ,decorator param is hello worldbefore func1......in func1()......after func1......before func2 ,decorator param is hello worldbefore func2......in func2()......a=1,b=2after func2......before func3 ,decorator param is hello worldbefore func3......in func3()......a=1,b=2c=100after func3......
1.2 被装饰器对象是类
被装饰器对象为类时,装饰器的作用是类在初始化的时候做功能增强,即可以在类初始化之前或者之后做一些功能增强,所以下面所说的被装饰对象有无参数是针对类的初始化函数__init__有无参数而言的,主要有以下几种情况:
1.2.1 装饰器无参数,被装饰类无参数
def decorator(cls): def _decorator(): print("before class {name} init......".format(name=cls.__name__)) obj=cls() print("after class {name} init......".format(name=cls.__name__)) return obj return _decorator@decoratorclass Test(object): def __init__(self): print("in class {name} init function......".format(name=Test.__name__)) def func(self): print("in class {name} func()".format(name=Test.__name__))if __name__=="__main__": test=Test() test.func()
运行结果如下:
before class Test init......in class _decorator init function......after class Test init......in class _decorator func()
1.2.2 装饰器无参数,被装饰类有参数
def decorator(cls): def _decorator(*args,**kwargs): print("before class {name} init......".format(name=cls.__name__)) obj=cls(*args,**kwargs) print("after class {name} init......".format(name=cls.__name__)) return obj return _decorator@decoratorclass Test(object): def __init__(self,a,b=10): print("in class {name} init function......".format(name=Test.__name__)) print("a={a},b={b}".format(a=a,b=b)) def func(self): print("in class {name} func()".format(name=Test.__name__))if __name__=="__main__": test=Test(2,20) test.func()
执行结果如下:
before class Test init......in class _decorator init function......a=2,b=20after class Test init......in class _decorator func()
1.2.3 装饰器有参数,被装饰类无参数
def wrapper(name="hello world"): def decorator(cls): def _decorator(): print("before class {name} init......".format(name=cls.__name__)) obj=cls() print("after class {name} init......".format(name=cls.__name__)) return obj return _decorator return decorator@wrapper("hello world")class Test(object): def __init__(self): print("in class {name} init function......".format(name=Test.__name__)) def func(self): print("in class {name} func()".format(name=Test.__name__))if __name__=="__main__": test=Test() test.func()
执行结果如下:
before class Test init......in class _decorator init function......after class Test init......in class _decorator func()
1.2.4 装饰器有参数,被装饰类有参数
def wrapper(name="hello world"): def decorator(cls): def _decorator(*args,**kwargs): print("before class {name} init......".format(name=cls.__name__)) obj=cls(*args,**kwargs) print("after class {name} init......".format(name=cls.__name__)) return obj return _decorator return decorator@wrapper("hello world")class Test(object): def __init__(self,a,b=10): print("in class {name} init function......".format(name=Test.__name__)) print("a= {a} b={b}".format(a=a,b=b)) def func(self): print("in class {name} func()".format(name=Test.__name__))if __name__=="__main__": test=Test(2,b=20) test.func()
运行结果如下:
before class Test init......in class _decorator init function......a= 2 b=20after class Test init......in class _decorator func()
1.3 被装饰对象是类中的方法
当被装饰对象是类中的方法时,装饰器的作用是对类中的方法进行功能加强,此时需要注意的是装饰器的内层函数需要增加一个self形参
1.3.1 装饰器无参数,被装饰类中的方法无参数
def decorator(func): def _decorator(self): print("before method {name}......".format(name=func.__name__)) obj = func(self) print("after method {name} ......".format(name=func.__name__)) return obj return _decoratorclass Test(object): def __init__(self, a=1, b=10): self.a = a self.b = b @decorator def func(self): print("in class {name} func()".format(name=Test.__name__)) print("a={a} b={b}".format(a=self.a, b=self.b))if __name__ == "__main__": test = Test() test.func()
执行结果如下:
before method func......in class Test func()a=1 b=10after method func ......
1.3.2 装饰器无参数,被装饰类中的方法有参数
(func): def _decorator(self,*args,**kwargs): print("before method {name} ......".format(name=func.__name__)) obj=func(self,*args,**kwargs) print("after method {name} ......".format(name=func.__name__)) return obj return _decoratorclass Test(object): def __init__(self,a=1,b=10): self.a=a self.b=b @decorator def func(self,c,d=20): print("in class {name} func()".format(name=Test.__name__)) print("a={a} b={b}".format(a=self.a,b=self.b)) print("c={c} d={d}".format(c=c,d=d))if __name__=="__main__": test=Test() test.func(2,d=20)
执行结果如下:
before method func ......in class Test func()a=1 b=10c=2 d=20after method func ......
1.3.3 装饰器有参数,被装饰类中的方法无参数
def wrapper(name="hello world"): def decorator(func): def _decorator(self): print("before method {name} ......".format(name=func.__name__)) print("name = {name}".format(name=name)) obj=func(self) print("after method {name} ......".format(name=func.__name__)) return obj return _decorator return decoratorclass Test(object): def __init__(self,a=1,b=10): self.a=a self.b=b @wrapper(name="Test.func") def func(self): print("in class {name} func()".format(name=Test.__name__)) print("a={a} b={b}".format(a=self.a,b=self.b))if __name__=="__main__": test=Test() test.func()
执行结果如下:
before method func ......name = Test.funcin class Test func()a=1 b=10after method func ......
1.2.4 装饰器有参数,被装饰类中的方法有参数
def wrapper(name="hello world"): def decorator(func): def _decorator(self,*args,**kwargs): print("before metthod {name} ......".format(name=func.__name__)) print("name = {name}".format(name=name)) obj=func(self,*args,**kwargs) print("after method {name} ......".format(name=func.__name__)) return obj return _decorator return decoratorclass Test(object): def __init__(self,a=1,b=10): self.a=a self.b=b @wrapper(name="Test.func") def func(self,c,d=20): print("in class {name} func()".format(name=Test.__name__)) print("a={a} b={b}".format(a=self.a,b=self.b)) print("c={c} d={d}".format(c=c,d=d))if __name__=="__main__": test=Test() test.func(2,d=20)
执行结果如下:
before metthod func ......name = Test.funcin class Test func()a=1 b=10c=2 d=20after method func ......
二、 装饰器是类
2.1 被装饰对象是函数
装饰器是类,被装饰对象是函数的时候,是通过装饰器类初始化的时候将被装饰对象函数传递给装饰器类,然后通过自动调用装饰器类中的__call__函数实现对被装饰对象的前后处理,即在这种情况下,只需要在__call__函数中编写在调用被装饰对象前后进行操作的代码即可
2.1.1 装饰器无参数,被装饰对象无参数
class decorator(object): def __init__(self,func): self.func=func def __call__(self): print("before func {func}()...".format(func=self.func.__name__)) result=self.func() print("after func {func}()...".format(func=self.func.__name__)) return result@decoratordef func(): print("in func func()...")if __name__=="__main__": func()
执行结果如下:
before func func()...in func func()...after func func()...
2.1.2 装饰器无参数,被装饰对象有参数
class decorator(object): def __init__(self,func): self.func=func def __call__(self,*args,**kwargs): print("before func {func}()...".format(func=self.func.__name__)) result=self.func(*args,**kwargs) print("after func {func}()...".format(func=self.func.__name__)) return result@decoratordef func(a,b=10): print("in func func()...") print("a= {a} b={b}".format(a=a,b=b))if __name__=="__main__": func(2,b=20)
执行结果如下:
before func func()...in func func()...a= 2 b=20after func func()...
2.1.3 装饰器有参数,被装饰对象无参数
(object): def __init__(self,name="hello world"): self.name=name def __call__(self,func): def wrapper(): print("before func {func}()...".format(func=func.__name__)) print("name= {name}".format(name=self.name)) result=func() print("after func {func}()...".format(func=func.__name__)) return result return wrapper@decorator()def func1(): print("in func func2()...")@decorator("func2_decorator")def func2(): print("in func func2()...")@decorator(name="func3_decorator")def func3(): print("in func func3()...")if __name__=="__main__": func1() func2() func3()
执行结果如下:
before func func1()...name= hello worldin func func2()...after func func1()...before func func2()...name= func2_decoratorin func func2()...after func func2()...before func func3()...name= func3_decoratorin func func3()...after func func3()...
2.1.4 装饰器有参数,被装饰器对象有参数
(object): def __init__(self,name="hello world"): self.name=name def __call__(self,func): def wrapper(*args,**kwargs): print("before func {func}()...".format(func=func.__name__)) print("name= {name}".format(name=self.name)) result=func(*args,**kwargs) print("after func {func}()...".format(func=func.__name__)) return result return wrapper@decorator()def func1(): print("in func func2()...")@decorator("func2_decorator")def func2(a): print("in func func2()...") print("a={a}".format(a=a))@decorator(name="func3_decorator")def func3(a,b=10): print("in func func3()...") print("a={a}, b= {b}".format(a=a,b=b))if __name__=="__main__": func1() func2(10) func3(2,b=20)
执行结果如下:
before func func1()...name= hello worldin func func2()...after func func1()...before func func2()...name= func2_decoratorin func func2()...a=10after func func2()...before func func3()...name= func3_decoratorin func func3()...a=2, b= 20after func func3()...
2.2 被装饰器对象是类
同样,当被装饰对象是类是,装饰器的作用是对被装饰类的初始化方法进行功能加强,而装饰器则是以类的形式定义的
2.2.1 装饰器无参数,被装饰类无参数
class decorator(object): def __init__(self,cls): self.cls=cls def __call__(self): print("before init clsss {cls}...".format(cls=self.cls.__name__)) obj=self.cls() print("after init class {cls}...".format(cls=self.cls.__name__)) return obj@decoratorclass Test(): def __init__(self): print("in Test class __init__ func...") def test(self): print("in Test class test func...")if __name__=="__main__": t=Test() t.test()
执行结果如下:
before init clsss Test...in Test class __init__ func...after init class Test...in Test class test func...
2.2.2 装饰器无参数,被装饰类有参数
class decorator(object): def __init__(self,cls): self.cls=cls def __call__(self,*args,**kwargs): print("before init clsss {cls}...".format(cls=self.cls.__name__)) obj=self.cls(*args,**kwargs) print("after init class {cls}...".format(cls=self.cls.__name__)) return obj@decoratorclass Test(): def __init__(self,a,b=10): print("in Test class __init__ func...") print("a={a} b={b}".format(a=a,b=b)) def test(self): print("in Test class test func...")if __name__=="__main__": t=Test(2,b=20) t.test()
执行结果如下:
before init clsss Test...in Test class __init__ func...a=2 b=20after init class Test...in Test class test func...
2.2.3 装饰器有参数,被装饰类无参数
class decorator(object): def __init__(self,name="hello world"): self.name=name def __call__(self,cls): def wrapper(): print("before init class {cls}....".format(cls=cls.__name__)) obj=cls() print("after init class {cls}...".format(cls=cls.__name__)) return obj return wrapper@decorator(name="Test Class")class Test(): def __init__(self): print("in Test class __init__ func...") def test(self): print("in Test class test func...")if __name__=="__main__": t=Test() t.test()
执行结果如下:
before init class Test....in Test class __init__ func...after init class Test...in Test class test func...
2.2.4 装饰器有参数,被装饰类有参数
class decorator(object): def __init__(self,name="hello world"): self.name=name def __call__(self,cls): def wrapper(*args,**kwargs): print("before init class {cls}....".format(cls=cls.__name__)) obj=cls(*args,**kwargs) print("after init class {cls}...".format(cls=cls.__name__)) return obj return wrapper@decorator(name="Test Class")class Test(): def __init__(self,a,b=10): print("in Test class __init__ func...") print("a={a}, b={b}".format(a=a,b=b)) def test(self): print("in Test class test func...")if __name__=="__main__": t=Test(2,b=20) t.test()
执行结果如下:
before init class Test....in Test class __init__ func...a=2, b=20after init class Test...in Test class test func...
2.3 被装饰对象是类中的方法
2.3.1 装饰器无参数,被装饰类中的方法无参数
class decorator(object): def __init__(self,func): self.func=func def __call__(self): print("before func {func}...".format(func=self.func.__name__)) results=self.func(self) print("after func {func}...".format(func=self.func.__name__)) return resultsclass Test(): def __init__(self): print("in Test class __init__ func...") @decorator def test(self): print("in Test class test func...")if __name__=="__main__": t=Test() t.test()
执行结果如下:
in Test class __init__ func...before func test...in Test class test func...after func test...
2.3.2 装饰器无参数,被装饰类中的方法有参数
class decorator(object): def __init__(self,func): self.func=func def __call__(self,*args,**kwargs): print("before func {func}...".format(func=self.func.__name__)) results=self.func(self,*args,**kwargs) print("after func {func}...".format(func=self.func.__name__)) return resultsclass Test(): def __init__(self): print("in Test class __init__ func...") @decorator def test(self,a,b=10): print("in Test class test func...") print("a={a} b={b}".format(a=a,b=b))if __name__=="__main__": t=Test() t.test(2,b=20)
执行结果如下:
in Test class __init__ func...before func test...in Test class test func...a=2 b=20after func test...
2.3.3 装饰器有参数,被装饰类中的方法无参数
class decorator(object): def __init__(self,name="hello world"): self.name=name def __call__(self,func): def wrapper(self): print("before func {func}...".format(func=func.__name__)) results=func(self) print("after func {func}...".format(func=func.__name__)) return results return wrapperclass Test(): def __init__(self): print("in Test class __init__ func...") @decorator(name="Test_test") def test(self): print("in Test class test func...")if __name__=="__main__": t=Test() t.test()
执行结果如下:
in Test class __init__ func...before func test...in Test class test func...after func test...
2.3.4 装饰器有参数,被装饰类中的方法有参数
class decorator(object): def __init__(self,name="hello world"): self.name=name def __call__(self,func): def wrapper(self,*args,**kwargs): print("before func {func}...".format(func=func.__name__)) results=func(self,*args,**kwargs) print("after func {func}...".format(func=func.__name__)) return results return wrapperclass Test(): def __init__(self): print("in Test class __init__ func...") @decorator(name="Test_test") def test(self,a,b=10): print("in Test class test func...") print("a={a}, b={b}".format(a=a,b=b))if __name__=="__main__": t=Test() t.test(2,b=20)
执行结果如下:
in Test class __init__ func...before func test...in Test class test func...a=2, b=20after func test...
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~