class Example(object):
def the_example(self):
itsProblem = "problem"
theExample = Example()
print(theExample.itsProblem)
如何访问类的变量?我试过添加这个定义:
def return_itsProblem(self):
return itsProblem
然而,这也失败了。
答案 0 :(得分:112)
答案,用几句话
在您的示例中,itsProblem
是一个局部变量。
您必须使用self
来设置和获取实例变量。您可以在__init__
方法中进行设置。然后你的代码将是:
class Example(object):
def __init__(self):
self.itsProblem = "problem"
theExample = Example()
print(theExample.itsProblem)
但是如果你想要一个真正的类变量,那么直接使用类名:
class Example(object):
itsProblem = "problem"
theExample = Example()
print(theExample.itsProblem)
print (Example.itsProblem)
但请注意这一点,因为theExample.itsProblem
会自动设置为等于Example.itsProblem
,但根本不是同一个变量,可以单独更改。
一些解释
在Python中,可以动态创建变量。因此,您可以执行以下操作:
class Example(object):
pass
Example.itsProblem = "problem"
e = Example()
e.itsSecondProblem = "problem"
print Example.itsProblem == e.itsSecondProblem
打印
真
因此,这正是您使用前面的示例所做的。
实际上,在Python中我们使用self
作为this
,但它不止于此。 self
是任何对象方法的第一个参数,因为第一个参数始终是对象引用。这是自动的,无论你是否称它为self
。
这意味着你可以做到:
class Example(object):
def __init__(self):
self.itsProblem = "problem"
theExample = Example()
print(theExample.itsProblem)
或:
class Example(object):
def __init__(my_super_self):
my_super_self.itsProblem = "problem"
theExample = Example()
print(theExample.itsProblem)
它完全一样。 任何对象方法的第一个参数是当前对象,我们只将其称为self
作为约定。并且只向该对象添加一个变量,就像从外部。
现在,关于类变量。
当你这样做时:
class Example(object):
itsProblem = "problem"
theExample = Example()
print(theExample.itsProblem)
您会注意到我们首先设置一个类变量,然后我们访问一个对象(实例)变量。我们从不设置这个对象变量,但是它有效,这怎么可能?
嗯,Python试图先得到对象变量,但是如果它找不到它,会给你类变量。 警告:类变量在实例之间共享,而对象变量则不是。
作为结论,永远不要使用类变量来设置对象变量的默认值。请使用__init__
。
最后,您将了解到Python类是实例,因此也是对象本身,这为理解上述内容提供了新的见解。一旦你意识到这一点,请稍后再回来看看。
答案 1 :(得分:9)
您正在声明一个局部变量,而不是一个类变量。要设置实例变量(属性),请使用
class Example(object):
def the_example(self):
self.itsProblem = "problem" # <-- remember the 'self.'
theExample = Example()
theExample.the_example()
print(theExample.itsProblem)
要设置class variable(a.k.a。静态成员),请使用
class Example(object):
def the_example(self):
Example.itsProblem = "problem"
# or, type(self).itsProblem = "problem"
# depending what you want to do when the class is derived.
答案 2 :(得分:0)
如果您有一个实例函数(即一个自我传递的函数),您可以使用self来使用self.__class__
例如在下面的代码中,tornado创建了一个处理get请求的实例,但是我们可以抓住get_handler
类并使用它来保存riak客户端,这样我们就不需要为每个请求创建一个。
import tornado.web
import riak
class get_handler(tornado.web.requestHandler):
riak_client = None
def post(self):
cls = self.__class__
if cls.riak_client is None:
cls.riak_client = riak.RiakClient(pb_port=8087, protocol='pbc')
# Additional code to send response to the request ...
答案 3 :(得分:-1)
实现return语句,如下例所示!你应该好。我希望它对某人有所帮助..
class Example(object):
def the_example(self):
itsProblem = "problem"
return itsProblem
theExample = Example()
print theExample.the_example()