我正在尝试理解python类中的self关键字。因此,我编了一个简单的课程:
class Question(object):
"""A class for answering my OO questions about python.
attributes: a_number"""
def __init__():
print "You've initialized a Question!"
def myself_add(self, new_number):
self.a_number += new_number在类定义下面的__main__函数中,我正在运行代码
my_q = Question
print my_q
my_q.a_number = 12
print 'A number:',my_q.a_number
my_q.myself_add(3)
print 'A number:',my_q.a_number我得到的结果(包括错误)是
<class '__main__.Question'>
A number: 12
Traceback (most recent call last):
File "question.py", line 21, in <module>
my_q.myself_add(3)
TypeError: unbound method myself_add() must be called with Question instance as first argument (got int instance instead)我试图理解为什么myself_add方法被认为是不绑定的。那是什么意思?为什么它不知道我是在Question类的一个实例上调用它呢?另外,为什么我的__init__打印不发生?
发布于 2017-03-17 16:33:11
为了创建一个实例,您需要编写Question()而不是Question。
__init__应该至少采用自我论证
您还可能希望在self.a_number中初始化__init__或放入类主体中,否则如果不执行my_q.a_number = 12,则myself_add调用将失败。
发布于 2017-03-17 16:35:53
“自我”的论点可以是任何东西,但按惯例被称为“自我”。
默认情况下,它由python传递给您。
您可以尝试运行这个简单的代码片段来了解我的意思:
class A(object):
def __init__(self):
pass
def check(self, checked):
print self is checked然后从命令行:
a=A()
a.check(a)你可以这样做:
In [74]: b=A()
In [75]: a.check(b)
False在这里,我创建了两个A的实例,一个叫做b,只有当把一个自我的实例和一个自身的实例进行比较时,才是正确的。
希望这是合理的。
特别是在您的情况下,您的类Question需要实例化(Question()),而您的__init__需要一个参数(自定义)。
当函数被绑定时,您可能会发现这个答案很有用:
What is the difference between a function, an unbound method and a bound method? (但可能是提前出价)
发布于 2017-03-17 16:42:44
首先,当初始化类的实例时,使用开始和结束括号,它按照约定调用__init__方法。
my_q = Question()但是,在您的示例中,您的__init__方法没有绑定到使用self的对象,因此,如果您按原样运行它将导致错误,
my_q = Question()
TypeError: __init__() takes no arguments (1 given)
>>> 您需要使用__init__初始化self,以便实例能够对对象进行隐式调用。
def __init__(self):现在,程序顺利运行,第一个打印就是my_q对象本身。
>>>
You've initialized a Question!
<__main__.Question object at 0x028ED2F0>
A number: 12
A number: 15https://stackoverflow.com/questions/42862501
复制相似问题