Python中的雙下劃線:特殊方法和屬性的魔法世界!
Python中的特殊方法和屬性,我們可以了解到這些功能是如何為自定義類和對(duì)象提供強(qiáng)大的控制和自定義選項(xiàng)的。
這些特殊方法和屬性具有特定的名稱和用途,以雙下劃線__開頭和結(jié)尾。它們?cè)试S覆蓋默認(rèn)行為,從而實(shí)現(xiàn)更靈活的對(duì)象交互和自定義類的行為。
特殊方法(Magic Methods)
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 = age
2、 __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] = value
7、__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 StopIteration
9、__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.items
11、__eq__(self, other): 相等性比較
__eq__方法定義了對(duì)象的相等性比較,可通過obj == other來調(diào)用。
class Point:
def __eq__(self, other):
return self.x == other.x and self.y == other.y
12、__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)各種需求和場景。