十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
上一篇:由浅入深,走进Python装饰器-----第四篇:进阶--函数装饰类
创新互联建站专注为客户提供全方位的互联网综合服务,包含不限于做网站、成都做网站、凉山州网络推广、重庆小程序开发公司、凉山州网络营销、凉山州企业策划、凉山州品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联建站为所有大学生创业者提供凉山州建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com
类装饰器
@类
类
# 用类装饰器来扩展原函数, 通过对象函数化触发__call__方法,进行返回
class KuoZhan():
def __call__(self,cls):
return self.newfunc(cls)
def good(self):
print("新增的方法!")
def newfunc(self,cls):
def in_newfunc():
cls.addpty = "新增的属性"
cls.good = KuoZhan.good
# 此处返回的是一个实例化对象
return cls()
return in_newfunc
@KuoZhan() #1. KuoZhan() ==> obj 2. @KuoZhan()==> @obj ==> obj( ) 3. @KuoZhan() == obj( MyClass), ,触发__call__ ,得到 in_newfunc
class MyClass():
def func(self):
print("我是原类的方法")
# MyClass实际就是in_newfunc, MyClass() == in_newfunc() , 所以 obj = cls()
# 对象调用方式
obj = MyClass()
obj.func()
obj.good()
print(obj.addpty)
>>>我是原类的方法
>>>新增的方法啦!
>>>新增的属性
# 用带参数类装饰器扩展原函数, 通过对象函数化触发__call__方法,进行返回
class KuoZhan():
# 带参数的装饰器,等于实例化对象,触发__init__,传递参数
def __init__(self,num):
self.num = num
def __call__(self,cls):
if self.num == 1:
return self.newfunc(cls)
else:
return self.newfunc2(cls)
def good(self):
print("新增的方法!")
def newfunc(self,cls):
def in_newfunc():
cls.addpty = "新增的属性"
cls.good = KuoZhan.good
# 此处返回的是一个实例化对象
return cls()
return in_newfunc
def newfunc2(self,cls):
pass
@KuoZhan(1) #1. KuoZhan() ==> obj 2. @KuoZhan()==> @obj ==> obj( ) 3. @KuoZhan() == obj( MyClass), ,触发__call__ ,得到 in_newfunc
class MyClass():
def func(self):
print("我是原类的方法")
# MyClass实际就是in_newfunc, MyClass() == in_newfunc() , 所以 obj = cls()
# 对象调用方式
obj = MyClass()
obj.func()
obj.good()
print(obj.addpty)
>>>我是原类的方法
>>>新增的方法啦!
>>>新增的属性
# 用类装饰器来扩展原函数, 直接通过类方法修饰后,进行返回
class KuoZhan():
def good():
print("新增的方法啦!")
def newfunc(cls):
def in_newfunc():
cls.addpty = "新增的属性"
cls.good = KuoZhan.good
# 此处返回的是一个类
return cls
return in_newfunc
# 类.方法 的方式
@KuoZhan.newfunc #1. MyClass = KuoZhan.newfunc(MyClass) ==> MyClass = in_newfunc
class MyClass():
def func():
print("我是原类的方法")
obj = MyClass()
obj.func()
obj.good()
print(obj.addpty)
>>>我是原类的方法
>>>新增的方法啦!
>>>新增的属性
# 用类装饰器来扩展原函数, 通过对象函数化触发__call__方法,进行返回
class KuoZhan():
def __call__(self,cls):
return self.newfunc(cls)
def func(self):
print("新增的方法!")
def newfunc(self,cls):
def in_newfunc():
cls.addpty = "新增的属性"
cls.func = KuoZhan.func
# 此处将原方法变成属性
cls.func2 = cls.func2(self)
# 此处返回的是一个实例化对象,使用的是绑定对象方法,所以上句代码使用绑定对象方法
return cls()
return in_newfunc
@KuoZhan() #1. KuoZhan() ==> obj 2. @KuoZhan()==> @obj ==> obj( ) 3. @KuoZhan() == obj( MyClass), ,触发__call__ ,得到 in_newfunc
class MyClass():
addpty = "原有的属性"
def func(self):
print("我是原类的方法")
def func2(self):
return "我是原类的方法2"
# MyClass实际就是in_newfunc, MyClass() == in_newfunc() , 所以 obj = cls()
obj = MyClass()
obj.func()
print(obj.addpty)
print(obj.func2)
>>>新增的方法!
>>>新增的属性
>>>我是原类的方法2
# 用类装饰器来扩展原函数, 通过直接调用类方法,进行返回
class KuoZhan():
def func():
print("新增的方法!")
def newfunc(cls):
def in_newfunc():
cls.addpty = "新增的属性"
cls.func = KuoZhan.func
# 注意直接使用类方法,不用额外参数
cls.func2 = cls.func2()
# 此处返回的是一个类
return cls
return in_newfunc
# 类.方法的方式
@KuoZhan.newfunc #1. MyClass = KuoZhan.newfunc(MyClass) ==> MyClass = in_newfunc
class MyClass():
addpty = "原有的属性"
def func():
print("我是原类的方法")
def func2():
return "我是原类的方法2"
# MyClass实际就是in_newfunc, MyClass() == in_newfunc() , 所以 obj = cls()
obj = MyClass()
obj.func()
print(obj.addpty)
print(obj.func2)
>>>新增的方法!
>>>新增的属性
>>>我是原类的方法2