探索Python中雙下劃線的特殊方法屬性魔法世界
特殊方法(Magic Methods)
Python中的特殊方法和屬性,我們可以了解到這些功能是如何為自定義類和對(duì)象提供強(qiáng)大的控制和自定義選項(xiàng)的。
這些特殊方法和屬性具有特定的名稱和用途,以雙下劃線__開頭和結(jié)尾。它們?cè)试S覆蓋默認(rèn)行為,從而實(shí)現(xiàn)更靈活的對(duì)象交互和自定義類的行為。
1. __init__(self, ...): 構(gòu)造方法
__init__是在創(chuàng)建新對(duì)象時(shí)首先調(diào)用的方法。用于初始化對(duì)象的屬性和執(zhí)行任何必要的設(shè)置。通常會(huì)在自定義類中定義的第一個(gè)方法。
class Person:
def __init__(self, name, age):
self.name = name
self.age = age2. __str__(self): 字符串表示
__str__方法定義了對(duì)象的字符串表示。使用str(obj)或print(obj)時(shí),將調(diào)用此方法。
class Person:
def __str__(self):
return f"{self.name}, {self.age} years old"3. __repr__(self): 官方字符串表示
__repr__方法返回對(duì)象的"官方"字符串表示,通常是一個(gè)可以用來重新創(chuàng)建該對(duì)象的表達(dá)式。它對(duì)于調(diào)試和開發(fā)非常有用。
class Person:
def __repr__(self):
return f"Person('{self.name}', {self.age})"4. __len__(self): 長度
__len__方法定義了對(duì)象的長度,可以通過len(obj)來調(diào)用。
class MyList:
def __init__(self, items):
self.items = items
def __len__(self):
return len(self.items)5. __getitem__(self, key): 獲取元素
__getitem__方法用于通過鍵或索引訪問對(duì)象的元素,可通過obj[key]來調(diào)用。
class MyList:
def __getitem__(self, index):
return self.items[index]6. __setitem__(self, key, value): 設(shè)置元素
__setitem__方法允許您通過鍵或索引設(shè)置對(duì)象的元素,可通過obj[key] = value來調(diào)用。
class MyList:
def __setitem__(self, index, value):
self.items[index] = value7. __delitem__(self, key): 刪除元素
__delitem__方法定義了刪除對(duì)象元素的操作,可通過del obj[key]來調(diào)用。
class MyList:
def __delitem__(self, index):
del self.items[index]8. __iter__(self): 迭代器
__iter__方法返回一個(gè)可迭代對(duì)象,通常與__next__方法一起使用,實(shí)現(xiàn)對(duì)象的迭代。
class MyList:
def __iter__(self):
self.index = 0
return self
def __next__(self):
if self.index < len(self.items):
result = self.items[self.index]
self.index += 1
return result
else:
raise StopIteration9. __next__(self): 下一個(gè)迭代值
__next__方法用于返回迭代器的下一個(gè)值,通常與__iter__方法一起使用,可在循環(huán)中調(diào)用。
10. __contains__(self, item): 包含性檢查
__contains__方法用于判斷對(duì)象是否包含某個(gè)元素,可通過item in obj來調(diào)用。
class MyList:
def __contains__(self, item):
return item in self.items11. __eq__(self, other): 相等性比較
__eq__方法定義了對(duì)象的相等性比較,可通過obj == other來調(diào)用。
class Point:
def __eq__(self, other):
return self.x == other.x and self.y == other.y12. __ne__(self, other): 不相等性比較
__ne__方法定義了對(duì)象的不相等性比較,可通過obj != other來調(diào)用。
13. __lt__(self, other): 小于比較
__lt__方法定義了對(duì)象的小于比較,可通過obj < other來調(diào)用。
14. __le__(self, other): 小于等于比較
__le__方法定義了對(duì)象的小于等于比較,可通過obj <= other來調(diào)用。
15. __gt__(self, other): 大于比較
__gt__方法定義了對(duì)象的大于比較,可通過obj > other來調(diào)用。
16. __ge__(self, other): 大于等于比較
__ge__方法定義了對(duì)象的大于等于比較,可通過obj >= other來調(diào)用。
這些特殊方法允許自定義類的行為,使其能夠按照需求進(jìn)行構(gòu)建和交互。通過覆蓋這些方法,可以實(shí)現(xiàn)更高級(jí)的功能,例如自定義容器類、實(shí)現(xiàn)迭代器、支持比較操作等。
特殊屬性(Magic Attributes)
1. __doc__: 文檔字符串
__doc__屬性包含類或函數(shù)的文檔字符串,可以通過obj.__doc__來訪問。這對(duì)于文檔和注釋非常有用。
class MyClass:
"""這是我的類的文檔字符串。"""
print(MyClass.__doc__)2. __class__: 類
__class__屬性包含對(duì)象所屬的類,可以通過obj.__class__來訪問。
class MyClass:
pass
obj = MyClass()
print(obj.__class__)3. __name__: 模塊
名稱
__name__屬性包含模塊的名稱,對(duì)于模塊級(jí)別的代碼有用。
if __name__ == "__main__":
print("This code is executed only when the script is run directly.")4. __file__: 模塊文件路徑
__file__屬性包含模塊的文件路徑,對(duì)于模塊級(jí)別的代碼有用。
print(__file__)
5. __dict__: 屬性字典
__dict__屬性包含對(duì)象的屬性和方法的字典??梢詣?dòng)態(tài)地添加、修改或刪除對(duì)象的屬性。
class Person:
pass
person = Person()
person.name = "Alice"
person.age = 30
print(person.__dict__)6. __dir__(): 屬性和方法列表
__dir__()方法返回對(duì)象的屬性和方法的列表,可以通過dir(obj)來調(diào)用。這對(duì)于查看對(duì)象的可用成員非常有用。
class MyClass:
def my_method(self):
pass
print(dir(MyClass()))7. __slots__: 屬性限制
__slots__屬性允許限制類的屬性,使其只能包含指定的屬性,從而節(jié)省內(nèi)存。這在需要?jiǎng)?chuàng)建大量對(duì)象時(shí)很有用。
class MyObject:
__slots__ = ('name', 'age')
obj = MyObject()
obj.name = "Alice"
obj.age = 30
obj.address = "123 Main St." # 會(huì)引發(fā)異常,因?yàn)?address'不在__slots__中8. __bases__: 直接父類元組
__bases__屬性包含類的直接父類的元組,通常在類繼承和多重繼承時(shí)使用。
class Parent1:
pass
class Parent2:
pass
class Child(Parent1, Parent2):
pass
print(Child.__bases__) # 輸出 (<class '__main__.Parent1'>, <class '__main__.Parent2'>)9. __subclasses__(): 子類列表
__subclasses__()方法返回類的所有直接子類,通常與issubclass()函數(shù)一起使用。
class Parent:
pass
class Child1(Parent):
pass
class Child2(Parent):
pass
print(Parent.__subclasses__()) # 輸出 [<class '__main__.Child1'>, <class '__main__.Child2'>]10. __mro__: 方法解析順序
__mro__屬性包含類的方法解析順序元組(Method Resolution Order),通常在多重繼承中查找方法時(shí)使用。
class A:
def foo(self):
pass
class B(A):
def foo(self):
pass
class C(A):
def foo(self):
pass
class D(B, C):
pass
print(D.__mro__) # 輸出 (<class '__main__.D'>, <class '__main__.B'>, <class '__main__.C'>, <class '__main__.A'>, <class 'object'>)總結(jié)
特殊方法和屬性是Python中強(qiáng)大而靈活的工具,用于自定義類和對(duì)象的行為。
通過使用這些特殊方法和屬性,可以實(shí)現(xiàn)自定義的構(gòu)造函數(shù)、字符串表示、比較操作、迭代器等功能。特殊屬性則能夠訪問與類和模塊相關(guān)的元數(shù)據(jù)信息。
理解并靈活運(yùn)用這些特殊方法和屬性能夠更好地定制和控制Python代碼,使其適應(yīng)各種需求和場(chǎng)景。
以上就是探索Python中雙下劃線的特殊方法屬性魔法世界的詳細(xì)內(nèi)容,更多關(guān)于Python雙下劃線方法屬性的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
5行Python代碼實(shí)現(xiàn)圖像分割的步驟詳解
這篇文章主要介紹了5行Python代碼實(shí)現(xiàn)圖像分割的步驟詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
Python實(shí)現(xiàn)數(shù)據(jù)的序列化操作詳解
在日常開發(fā)中,對(duì)數(shù)據(jù)進(jìn)行序列化和反序列化是常見的數(shù)據(jù)操作,Python提供了兩個(gè)模塊方便開發(fā)者實(shí)現(xiàn)數(shù)據(jù)的序列化操作,即?json?模塊和?pickle?模塊。本文就為大家詳細(xì)講解這兩個(gè)模塊的使用,需要的可以參考一下2022-07-07
Pygame游戲開發(fā)之太空射擊實(shí)戰(zhàn)子彈與碰撞處理篇
相信大多數(shù)8090后都玩過太空射擊游戲,在過去游戲不多的年代太空射擊自然屬于經(jīng)典好玩的一款了,今天我們來自己動(dòng)手實(shí)現(xiàn)它,在編寫學(xué)習(xí)中回顧過往展望未來,下面開始講解子彈與碰撞處理,在本課中,我們將添加玩家與敵人之間的碰撞,以及添加供玩家射擊的子彈2022-08-08
Python3.9.1中使用split()的處理方法(推薦)
這篇文章主要介紹了Python3.9.1中使用split()的處理方法(推薦),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02

