讓實(shí)例打印出來(lái)好看
__str__
__repr__
class Student(object):
def __init__(self, name):
self.name = name
def __str__(self):
return 'Student object (name=%s)' % self.name
__repr__ = __str__
>>> print(Student('Michael'))
Student object (name: Michael)
#沒(méi)有__str__就會(huì)是這樣
#>>> print(Student('Michael'))
#<__main__.Student object at 0x109afb190>
>>> s = Student('Michael')
>>> s
Student object (name: Michael)
#沒(méi)有__repr__就會(huì)是這樣
<__main__.Student object at 0x109afb310>
__iter__
__next__
該方法返回一個(gè)迭代對(duì)象,然后,Python的for循環(huán)就會(huì)不斷調(diào)用該迭代對(duì)象的__next__()方法拿到循環(huán)的下一個(gè)值,直到遇到StopIteration錯(cuò)誤時(shí)退出循環(huán)。
class Fib(object):
def __init__(self):
self.a, self.b = 0, 1 # 初始化兩個(gè)計(jì)數(shù)器a,b
def __iter__(self):
return self # 實(shí)例本身就是迭代對(duì)象,故返回自己
def __next__(self):
self.a, self.b = self.b, self.a + self.b # 計(jì)算下一個(gè)值
if self.a > 100000: # 退出循環(huán)的條件
raise StopIteration()
return self.a # 返回下一個(gè)值
>>> for n in Fib():
... print(n)
...
1
1
2
3
5
...
46368
75025
__getitem__
Fib實(shí)例雖然能作用于for循環(huán),看起來(lái)和list有點(diǎn)像,但是,把它當(dāng)成list來(lái)使用還是不行
實(shí)現(xiàn)__getitem__()方法就可以按下標(biāo)訪問(wèn)數(shù)列的任意一項(xiàng)
list有個(gè)神奇的切片方法對(duì)于Fib卻報(bào)錯(cuò)。原因是__getitem__()傳入的參數(shù)可能是一個(gè)int,也可能是一個(gè)切片對(duì)象slice,所以要做判斷.
但是沒(méi)有對(duì)step參數(shù)作處理,也沒(méi)有對(duì)負(fù)數(shù)作處理,所以,要正確實(shí)現(xiàn)一個(gè)__getitem__()還是有很多工作要做的。
__getattr__
__call__
class Student(object):
def __init__(self, name):
self.name = name
def __call__(self):
print('My name is %s.' % self.name)
>>> s = Student('Michael')
>>> s() # self參數(shù)不要傳入
My name is Michael.
通過(guò)callable()函數(shù),我們就可以判斷一個(gè)對(duì)象是否是“可調(diào)用”對(duì)象。