python中布尔类型是特殊的_Python中的特殊方法以及应用详解
前言
Python 中的特殊方法主要是為了被解釋器調用的,因此應該盡量使用 len(my_object) 而不是 my_object.__len__() 這種寫法。在執行 len(my_object) 時,Python 解釋器會自行調用 my_object 中實現的 __len__ 方法。
除非有大量的元編程存在,直接調用特殊方法的頻率應遠小于實現它們的次數。
模擬數值類型
可以通過在自定義對象中實現 __add__ 和 __mul__ 等特殊方法 ,令其支持 +、* 等運算符。
如下面的模擬向量的 Vector 類:#?vector.py
from?math?import?hypot
class?Vector:
def?__init__(self,?x=0,?y=0):
self.x?=?x
self.y?=?y
def?__repr__(self):
return?f'Vector({self.x},?{self.y})'
def?__abs__(self):
return?hypot(self.x,?self.y)
def?__bool__(self):
return?bool(self.x?or?self.y)
def?__add__(self,?other):
return?Vector(self.x?+?other.x,?self.y?+?other.y)
def?__mul__(self,?scalar):
return?Vector(self.x?*?scalar,?self.y?*?scalar)
運行效果如下:>>> from vector import Vector
>>> v1 = Vector(2, 4)
>>> v2 = Vector(2, 1)
>>> v1 + v2
Vector(4, 5)
>>> v = Vector(3, 4)
>>> abs(v)
5.0
>>> v * 3
Vector(9, 12)
對象的字符串表示
Python 有一個 repr 內置函數,能把一個對象用字符串的形式表示出來。實際上這種字符串表達是通過對象內部的 __repr__ 特殊方法定義的。默認情況下,在控制臺里查看某個對象時,輸出的字符串一般是 這種形式。
__repr__ 返回的字符串應該準確、無歧義,并盡可能表示出該對象是如何創建的。比如前面的 Vector 對象,其 __repr__ 中定義的字符串形式類似于 Vector(3, 4),和對象初始化的語法非常近似。
__repr__ 和 __str__ 的區別在于,__str__ 是在向對象應用 str() 函數(或者用 print 函數打印某個對象)時被調用。其返回的字符串對終端用戶更友好。
如果只想實現其中一個特殊方法,__repr__ 應該是更優的選擇。在對象沒有實現 __str__ 方法的情況下,Python 解釋器會用 __repr__ 代替。#?myclass.py
class?MyClass:
def?__repr__(self):
return?'MyClass'
def?__str__(self):
return?'This?is?an?instance?of?MyClass'>>>?from?myclass?import?MyClass
>>>?my?=?MyClass()
>>>?my
MyClass
>>>?print(my)
This?is?an?instance?of?MyClass
自定義布爾值
Python 里有 bool 類型,但實際上任何對象都可以用在需要 bool 類型的上下文(比如 if 或 while 語句)中。為了判斷某個值 x 的真假,Python 會調用 bool(x) 返回 True 或 False。
默認情況下,自定義類的實例總是為真。除非這個類對于 __bool__ 或 __len__ 方法有自己的實現。
bool(x) 實際上調用了對象 x 中的 __bool__ 方法。如不存在 __bool__ 方法,則 bool(x) 會嘗試調用 x.__len__(),返回 0 則為 False,否則為 True。#?boolclass.py
class?BoolClass:
def?__init__(self):
self.list?=?[]
def?add(self,?item):
self.list.append(item)
def?__len__(self):
return?len(self.list)>>>?from?boolclass?import?BoolClass
>>>?b?=?BoolClass()
>>>?len(b)
0
>>>?bool(b)
False
>>>?b.add(1)
>>>?len(b)
1
>>>?bool(b)
True#?boolclass.py
class?BoolClass:
def?__init__(self):
self.list?=?[]
def?add(self,?item):
self.list.append(item)
def?__len__(self):
return?len(self.list)
def?__bool__(self):
return?bool(sum(self.list))>>>?from?boolclass?import?BoolClass
>>>?b?=?BoolClass()
>>>?b.add(1)
>>>?len(b)
1
>>>?bool(b)
True
>>>?b.add(-1)
>>>?len(b)
2
>>>?bool(b)
False
參考資料
Fluent Python
總結
以上是生活随笔為你收集整理的python中布尔类型是特殊的_Python中的特殊方法以及应用详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 小憩一会儿是什么意思 小憩一会儿意思说明
- 下一篇: 银狐犬的优缺点是什么(银狐犬忠心耿耿黏人