我有以下python代码段:
class myClass:
myVar = 'a'
def __init__(self):
self.myOtherVar = 'b'
myVar = 'c' # Gets assigned but only as a local variable.
print myVar # prints 'a' !
print self.myOtherVar # says 'self' not found
我的问题是这个;myVar
从内部打印myClass
和/或从中重新分配内容的正确方法是什么init
?
您面临的问题是因为您不了解类声明的作用域。类声明在其自己的范围内执行。执行完成后,将创建一个新的类对象,并将获得的范围作为类附加到该类__dict__
。
注意:不能从方法范围内搜索类范围!这意味着,你必须引用类的属性MyClass.attribute
时,里面的方法定义。
例如:
class MyClass:
var = 1
# we are executing this code as a single block
# so you must reference the variable as is usual
print(var)
# default values are *not* inside the definition.
# they are evaluated in the outer scope, so use plain "var" here
def method(self, a_default=var):
print(a_default)
def other_method(self):
# inside methods you are in a different scope
print(MyClass.var)
# equivalent *if* no "var" instance attributes exists
print(self.var)
注意:由于执行该类的声明时该类仍然不存在,因此无法MyClass
在MyClass
声明的“顶层”进行引用:
class MyClass:
var = 1
print(MyClass.var) # error: MyClass still doesn't exist.
这样做的副作用是以下代码:
class MyClass:
x = 1
results = list(i+x for i in range(10))
产生:
NameError Traceback (most recent call last)
<ipython-input-6-f1d4417b2e52> in <module>()
----> 1 class MyClass:
2 x = 1
3 results = list(i+x for i in range(10))
4
<ipython-input-6-f1d4417b2e52> in MyClass()
1 class MyClass:
2 x = 1
----> 3 results = list(i+x for i in range(10))
4
<ipython-input-6-f1d4417b2e52> in <genexpr>(.0)
1 class MyClass:
2 x = 1
----> 3 results = list(i+x for i in range(10))
4
NameError: name 'x' is not defined
因为生成器表达式(以及python3中的列表理解)实际上被认为是具有自己作用域的函数。由于未从内部函数范围中搜索类范围,x
因此无法找到。
您可以使用函数定义和默认值对此加以说明:
class MyClass:
x = 1
def _make_results(x=x):
return list(i+x for i in range(10))
results = _make_results()
del _make_results # otherwise it would be added as a method.
# or:
results = (lambda x=x: list(i+x for i in range(10)))()
这通常不是问题,因为类定义很少包含除方法定义和一些常量以外的任何内容。
关于类范围,SO已经存在一些问题:
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句