中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

由淺入深,走進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

阳曲县| 大理市| 荆州市| 沙雅县| 台州市| 乌拉特后旗| 沁源县| 古蔺县| 镇沅| 衡阳县| 樟树市| 岱山县| 邳州市| 永新县| 巧家县| 罗城| 昌吉市| 卓资县| 柳林县| 柞水县| 综艺| 新安县| 宁陕县| 册亨县| 浠水县| 睢宁县| 天祝| 江门市| 嫩江县| 禄劝| 汕尾市| 锡林浩特市| 曲松县| 永新县| 壤塘县| 兴安盟| 平江县| 武胜县| 阿克陶县| 西丰县| 鹤山市|