亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

由淺入深,走進Python裝飾器-----第五篇:進階--類裝飾類

發布時間:2020-08-19 16:42:02 來源:網絡 閱讀:564 作者:龍翔九天dl 欄目:編程語言

上一篇:由淺入深,走進Python裝飾器-----第四篇:進階--函數裝飾類


類裝飾器  
@類
類


4.1 用類裝飾器來擴展原類( 增加屬性和方法 )

# 用類裝飾器來擴展原函數,  通過對象函數化觸發__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)

>>>我是原類的方法
>>>新增的方法啦!
>>>新增的屬性

4.1.2 用帶參數的類裝飾器來擴展原類( 增加屬性和方法 )

# 用帶參數類裝飾器擴展原函數,  通過對象函數化觸發__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)

>>>我是原類的方法
>>>新增的方法啦!
>>>新增的屬性

4.2 用類裝飾器來擴展原類( 增加屬性和方法 )

# 用類裝飾器來擴展原函數, 直接通過類方法修飾后,進行返回
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)
>>>我是原類的方法
>>>新增的方法啦!
>>>新增的屬性

4.3 用類裝飾器來擴展原類( 改變屬性和方法 )

# 用類裝飾器來擴展原函數,  通過對象函數化觸發__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

4.4 用類裝飾器來擴展原類( 改變屬性和方法 )

# 用類裝飾器來擴展原函數,  通過直接調用類方法,進行返回
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
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

濮阳市| 齐齐哈尔市| 海淀区| 和硕县| 绥宁县| 寿阳县| 昔阳县| 关岭| 确山县| 宾阳县| 吴堡县| 成都市| 肇东市| 安塞县| 永仁县| 双辽市| 隆安县| 和平区| 赣州市| 弥渡县| 光泽县| 宿迁市| 五华县| 县级市| 江山市| 商城县| 青神县| 荆州市| 仙居县| 紫阳县| 青岛市| 沙河市| 定安县| 沁阳市| 彰武县| 白水县| 鹿邑县| 塔城市| 大悟县| 商城县| 略阳县|