本文实例讲述了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, in
print 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程序设计有所帮助。