本文實例講述了Python中__call__的用法,分享給大家供大家參考之用。具體方法如下:
先來看看如下示例代碼:
#call.py 一個class被載入的情況下。 class Next: List = [] def __init__(self,low,high) : for Num in range(low,high) : self.List.append(Num ** 2) def __call__(self,Nu): return self.List[Nu]
如果 這樣使用:
b = Next(1,7) print b.List print b(2)
那么回饋很正常:
[1, 4, 9, 16, 25, 36] 9
但如果這樣使用:
b = Next b(1,7) print b.List print b(2) $python ./call.py [1, 4, 9, 16, 25, 36] Traceback (most recent call last): File "cal.py", line 17, inprint b(2) TypeError: __init__() takes exactly 3 arguments (2 given)
__init__是初始化函數,在生成類的實例時執行。
而__call__是模擬()的調用,需要在實例上應用,因此這個實例自然是已經執行過__init__了。
你所舉的后面那個例子:
b = Next
這并不是創建實例,而是將class賦給一個變量。因此后面使用b進行的操作都是對Next類的操作,那么其實就是:
Next(1,7) print Next.List print Next(2)
希望本文所述對大家的Python程序設計有所幫助。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
