上一篇:由浅入深,走进Python装饰器-----第三篇:进阶--类装饰函数
函数装饰器
@函数
类
本篇只是用一个简单的例子,验证函数可以对类进行修饰, 但是由于返回的值为函数,并不是类, 把原有类的实例化调用方式变为了函数调用.
#### 要点:读者还应注意返回值为类或者对象时候的相应参数使用区别
3.1 用函数装饰器来扩展原类
def KuoZhan(cls):
def new_func():
print("类里新增的方法new_func")
def new_class():
cls.say = "类里新增的属性"
cls.new_func = new_func
# 此处返回类,注意和3.2返回的对象例子做参数对比,
return cls
return new_class
# 通过函数装饰器给类增加属性或者方法
@KuoZhan #1. @KuoZhan ==> KuoZhan( )
class MyClass():
def func():
print("我是原类里的方法func")
# 此处改变了原类的调用方式, 实际上MyClass已经是一个函数名了
# type(MyClass) = <class 'function'>
obj = MyClass()
# obj 拿到的是函数new_class的返回值cls
obj.func()
obj.new_func()
print(obj.say)
>>>我是原类里的方法func
>>>类里新增的方法new_func
>>>类里新增的属性
3.2 用函数装饰器来扩展原类
def KuoZhan(cls):
# 增加参数self
def new_func(self):
print("类里新增的方法new_func")
def new_class():
cls.say = "类里新增的属性"
cls.new_func = new_func
# 此处返回对象
return cls()
return new_class
# 通过函数装饰器给类增加属性或者方法
@KuoZhan #1. @KuoZhan ==> KuoZhan( )
class MyClass():
# 增加参数self
def func(self):
print("我是原类里的方法func")
# 此处改变了原类的调用方式, 实际上MyClass已经是一个函数名了
# type(MyClass) = <class 'function'>
obj = MyClass()
# obj 拿到的是函数new_class的返回值cls
obj.func()
obj.new_func()
print(obj.say)
>>>我是原类里的方法func
>>>类里新增的方法new_func
>>>类里新增的属性
3.3 用带参数的函数装饰器来扩展原类
def outer(n):
def KuoZhan1(cls):
def new_func():
print("类里新增的方法new_func")
def new_class():
cls.say = "类里新增的属性"
cls.new_func = new_func
# 此处返回类,注意和3.2返回的对象例子做参数对比,
return cls
return new_class
def KuoZhan2(cls):
pass
if n == 1:
return KuoZhan1
else:
return KuoZhan2
# 通过函数装饰器给类增加属性或者方法
@outer(1) #1. outer(1) ==> KuoZhan1 2.@out(1) == @KuoZhan1
class MyClass():
def func():
print("我是原类里的方法func")
# 此处改变了原类的调用方式, 实际上MyClass已经是一个函数名了
# type(MyClass) = <class 'function'>
obj = MyClass()
# obj 拿到的是函数new_class的返回值cls
obj.func()
obj.new_func()
print(obj.say)
>>>我是原类里的方法func
>>>类里新增的方法new_func
>>>类里新增的属性