濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 詳解Python常用的魔法方法

詳解Python常用的魔法方法

熱門(mén)標(biāo)簽:市場(chǎng)上的電銷(xiāo)機(jī)器人 儋州電話(huà)機(jī)器人 佛山400電話(huà)辦理 北京電銷(xiāo)外呼系統(tǒng)加盟 小蘇云呼電話(huà)機(jī)器人 地圖標(biāo)注面積 朝陽(yáng)手機(jī)外呼系統(tǒng) 所得系統(tǒng)電梯怎樣主板設(shè)置外呼 北瀚ai電銷(xiāo)機(jī)器人官網(wǎng)手機(jī)版

一、python魔法方法

Python的魔法方法會(huì)在特定的情況下自動(dòng)調(diào)用,且他們的方法名通常被雙下劃線(xiàn)包裹,之前我們學(xué)習(xí)的構(gòu)造函數(shù)和析構(gòu)函數(shù)就屬于魔法方法

二、運(yùn)算符重載

Python中同樣有運(yùn)算符重載,其實(shí)所有的運(yùn)算符都是使用了對(duì)應(yīng)的魔法方法來(lái)處理的對(duì)象的,魔法方法對(duì)應(yīng)的操作符如下

我們來(lái)舉一個(gè)簡(jiǎn)單的例子

class A:
    def __init__(self,x):
        self.x = x
    def __add__(self,other):
        return int(self.x)+int(other.x)
a = A(3.3)
b = A(5.2)
print(a+b)

類(lèi)似的還有反運(yùn)算重載和增量復(fù)制運(yùn)算,用處較少,不再解釋


三、打印操作的魔法方法

__str__(self):返回值是str類(lèi)型的,當(dāng)我們需要以字符串的形式輸出對(duì)象時(shí)(調(diào)用print時(shí)),就會(huì)自動(dòng)調(diào)用該方法,舉個(gè)例子

class A:
    def __str__(self):
        return '我真帥'

a = A()
print(a)# 我真帥

__repr__(self):返回值是str類(lèi)型的,當(dāng)我們直接在shell中輸入對(duì)象名并按下回車(chē),就會(huì)自動(dòng)調(diào)用該方法,他也有和__str__一樣的功能,但如果兩者你都重寫(xiě)了,在使用print時(shí),__str__的優(yōu)先級(jí)高,__repr__是給機(jī)器看的,__str__是給人看的,舉個(gè)例子

>>> class A:
    def __str__(self):
        return '我真帥'
    def __repr__(self):
        return '我是世界第一帥'

>>> a = A()
>>> a
我是世界第一帥
>>> print(a)
我真帥

四、屬性操作的魔法方法

  • __getattr__(self, name):定義當(dāng)用戶(hù)試圖獲取一個(gè)不存在的屬性時(shí)的行為,其中name是屬性名,是一個(gè)字符串,下同
  • __getattribute__(self, name):定義當(dāng)該類(lèi)的屬性被訪(fǎng)問(wèn)時(shí)的行為,該方法默認(rèn)返回該屬性的值
  • __setattr__(self, name, value):定義當(dāng)一個(gè)屬性被設(shè)置時(shí)的行為,value是給該屬性的值
  • __delattr__(self, name):定義當(dāng)一個(gè)屬性被刪除時(shí)的行為

例如:

class A:
    def __init__(self):
        self.id = "Pyhon"
    def __getattr__(self,name):
        print(name+"這個(gè)屬性不存在")
    def __getattribute__(self,name):
        print("我訪(fǎng)問(wèn)了"+name+"這個(gè)屬性")
        return super().__getattribute__(name)
    def __setattr__(self,name,value):
        print("將屬性"+name+"置為"+value)
        super().__setattr__(name,value)
    def __delattr__(self,name):
        print("將屬性"+name+"刪除了");
        super().__delattr__(name)
    def fun(self):
        pass
a = A()
a.name
a.name = "老師"
del a.name
a.fun()
# output:
# 將屬性id置為Pyhon
# 我訪(fǎng)問(wèn)了name這個(gè)屬性
# name這個(gè)屬性不存在
# 將屬性name置為老師
# 將屬性name刪除了
# 我訪(fǎng)問(wèn)了fun這個(gè)屬性

結(jié)果可以看出,當(dāng)我們?cè)L問(wèn)一個(gè)屬性的時(shí)候,先是調(diào)用了__getattribute__,如果該屬性不存在,則再調(diào)用__getattr__

使用這幾個(gè)的方法的時(shí)候,要注意不要陷入無(wú)限遞歸,運(yùn)算符重載的時(shí)候也容易犯這種錯(cuò)誤,例如下面的錯(cuò)誤

class A:
    def __init__(self):
        self.id = "Pyhon"
    def __setattr__(self,name,value):
        print("將屬性"+name+"置為"+value)
        if(name == "id"):
            self.id = value

a = A()

執(zhí)行這段程序的時(shí)候?qū)⑾萑霟o(wú)限遞歸,原因是在__setattr__中,直接給self對(duì)象的屬性賦值,而這又會(huì)調(diào)用__setattr__方法。

所以在__setattr__中,我們通常會(huì)使用父類(lèi)的__setattr__方法來(lái)給self對(duì)象的屬性賦值,這不會(huì)陷入無(wú)限遞歸,其他幾個(gè)方法和運(yùn)算符重載也是同理,上面程序訂正后如下

class A:
    def __init__(self):
        self.id = "Pyhon"
    def __setattr__(self,name,value):
        print("將屬性"+name+"置為"+value)
        if(name == "id"):
            super().__setattr__(name,value)

a = A()
# output
# 將屬性id置為Pyhon

五、描述符

  • __get__(self, instance, owner):通過(guò)其他實(shí)例對(duì)象來(lái)訪(fǎng)問(wèn)該類(lèi)的實(shí)例對(duì)象時(shí)會(huì)調(diào)用該方法,返回該實(shí)例對(duì)象的引用。其中instance是訪(fǎng)問(wèn)該對(duì)象的實(shí)例對(duì)象的引用,下同,owner是訪(fǎng)問(wèn)該對(duì)象的類(lèi)對(duì)象
  • __set__(self, instance, value):通過(guò)其他實(shí)例對(duì)象來(lái)給該類(lèi)的實(shí)例對(duì)象賦值時(shí)會(huì)調(diào)用該方法。其中value是給該對(duì)象賦的值
  • __delete__(self, instance):通過(guò)其他實(shí)例對(duì)象來(lái)刪除該類(lèi)的實(shí)例對(duì)象時(shí)會(huì)調(diào)用該方法
class Fit:
    def __init__(self):
        self.height = 180
        self.weight = 80
    def __get__(self,instance,owner):
        print("get:",instance,owner)
        return [self.height,self.weight]
    def __set__(self,instance,value):
        print("set:",instance,value)
        self.height = value
        self.weight = value/2
    def __delete__(self,instance):
        del self.height
        del self.weight
        print("delete:",instance)

class Test:
    fit = Fit()
        
t = Test()
print (t.fit)
t.fit = 190
del t.fit
# output:
# get: __main__.Test object at 0x0000023EFFA738C8> class '__main__.Test'>
# [180, 80]
# set: __main__.Test object at 0x0000023EFFA738C8> 190
# delete: __main__.Test object at 0x0000023EFFA738C8>

通常情況下,上面幾個(gè)魔法方法,當(dāng)我們需要定義一個(gè)屬性,且希望可以直接對(duì)該屬性進(jìn)行相應(yīng)的操作,而不是通過(guò)調(diào)用方法的方式來(lái)進(jìn)行操作時(shí),我們可以定義一個(gè)該屬性的類(lèi),實(shí)現(xiàn)上面幾個(gè)魔法方法,將需要用到的屬性作為其實(shí)例對(duì)象,這樣就完成了,例如上面的Fit,其實(shí)就是體型類(lèi),而Test中有一個(gè)體型屬性叫fit,我們?cè)贔it中定義了一些對(duì)Fit的實(shí)例對(duì)象操作時(shí)執(zhí)行的操作。

六、定制序列

  • __len__(self):定義當(dāng)該類(lèi)的實(shí)例對(duì)象被len()調(diào)用時(shí)的行為
  • __getitem__(self, key):定義獲取該類(lèi)的實(shí)例對(duì)象中指定元素的行為,也就是說(shuō)執(zhí)行self[key]時(shí)的行為
  • __setitem__(self, key, value):定義設(shè)置該類(lèi)的實(shí)例對(duì)象中指定元素的行為,相當(dāng)于self[key] = value
  • __delitem__(self, key):定義刪除該類(lèi)的實(shí)例對(duì)象中指定元素的新聞,相當(dāng)于del self[key]
class CountList:
    def __init__(self,*args):
        self.values = [x for x in args]#這是一個(gè)列表推導(dǎo)式,把a(bǔ)rgs里的元素作為values的元素
        self.count = {}.fromkeys(range(len(self.values)),0)

    def __len__(self):
        return len(self.values)

    def __getitem__(self,key):
        self.count[key] += 1;
        return self.values[key]

c = CountList(1,3,5,7,9,11)
print(c[1])
print(c[1]+c[2])
print(c.count)
# output:
# 3
# 8
# {0: 0, 1: 2, 2: 1, 3: 0, 4: 0, 5: 0}

該類(lèi)中的count是記錄對(duì)應(yīng)元素被訪(fǎng)問(wèn)的次數(shù),其他兩個(gè)也差不多,不再舉例了

七、迭代器

迭代器,就是提供了迭代方法的容器,而所謂的迭代方法,就是下面這兩個(gè)__iter____next__
可迭代,就是提供了__iter__方法的容器,我們之前講的字符串,列表,元組,字典,集合都是可迭代的,但他們不是迭代器,可以使用Python的內(nèi)置函數(shù)iter(iterable)來(lái)獲取他們相應(yīng)的迭代器,而迭代器使用next(iterator)可以獲取下一個(gè)元素,而這兩個(gè)方法其實(shí)就是調(diào)用了迭代器的__iter____next__

  • __iter__(self):定義獲取迭代器時(shí)的行為
  • __next__(self):定義獲取迭代器對(duì)應(yīng)的下一個(gè)元素時(shí)的行為
class Fb:
    def __init__(self,n = 20):
        self.a = 0
        self.b = 1
        self.n = n
    def __iter__(self):
        return self
    def __next__(self):
        t = self.a
        self.a = self.b
        self.b = t + self.b
        if(self.a = self.n):
            return self.a
        else:
            raise StopIteration

f = Fb()
for i in f:
    print(i,end=' ')
# output:1 1 2 3 5 8 13 

其中 raise 是返回一個(gè)異常,上面的程序等價(jià)于下面這個(gè)

class Fb:
    def __init__(self,n = 20):
        self.a = 0
        self.b = 1
        self.n = n
    def __iter__(self):
        return self
    def __next__(self):
        t = self.a
        self.a = self.b
        self.b = t + self.b
        if(self.a = self.n):
            return self.a
        else:
            raise StopIteration

f = Fb()
it = iter(f)
while True:
    try:
        i = next(it)
        print(i, end=' ')
    except StopIteration:
        break;

這樣我們就很清楚Python中for循環(huán)的原理了,先通過(guò)iter來(lái)獲取迭代器對(duì)象,然后不斷調(diào)用next來(lái)獲取下一個(gè)元素賦值給i,直到遇到StopIteration異常

到此這篇關(guān)于詳解Python常用的魔法方法的文章就介紹到這了,更多相關(guān)python魔法方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 詳解Python魔法方法之描述符類(lèi)
  • 總結(jié)Python常用的魔法方法
  • Python面向?qū)ο竽Хǚ椒ê蛦卫K代碼實(shí)例
  • Python魔法方法 容器部方法詳解
  • Python類(lèi)中的魔法方法之 __slots__原理解析
  • Python魔法方法功能與用法簡(jiǎn)介
  • Python魔法方法詳解
  • python魔法方法-屬性訪(fǎng)問(wèn)控制詳解
  • python魔法方法-屬性轉(zhuǎn)換和類(lèi)的表示詳解
  • python魔法方法-自定義序列詳解
  • Python中的魔法方法深入理解

標(biāo)簽:江蘇 金融催收 云南 酒泉 商丘 定西 龍巖 寧夏

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Python常用的魔法方法》,本文關(guān)鍵詞  詳解,Python,常用的,常,用的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解Python常用的魔法方法》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于詳解Python常用的魔法方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    鄂托克前旗| 邵阳县| 永川市| 西盟| 沈阳市| 乌兰察布市| 山阴县| 镇巴县| 梁河县| 洪雅县| 龙泉市| 运城市| 福贡县| 七台河市| 莎车县| 商丘市| 双柏县| 新密市| 华阴市| 沧源| 永春县| 三门峡市| 自贡市| 甘南县| 太湖县| 长汀县| 中阳县| 英吉沙县| 介休市| 花莲市| 上虞市| 河西区| 遂昌县| 天津市| 东丰县| 连州市| 宜宾市| 丹巴县| 香格里拉县| 黄石市| 中阳县|