希望这不是深夜效应,但我被一个非常简单的问题所困扰:
def test_getattr(v0):
v1 = "test1"
v2 = "test2"
v3 = "test3"
for k, v in locals().items():
print(k, v)
print(getattr(locals(), 'v1'))
test_getattr("test0")
输出按预期给出locals()dict项:
v0 test0
v3 test3
v1 test1
v2 test2
但随后死了:
根据初始输出,AttributeError:'dict'对象没有属性'v1'
v1在locals()'dict'中是 ,但是getattr()则另有说明。
这是我第一次使用locals(),但是我能找到的每一份文档都表明这应该有用。我错过了什么?
编辑/更新:非常感谢@martijn以获得以下答案。我设法通过将局部变量暂时分配给虚拟类来在getattr()中使用动态局部变量:
class Attr:
pass
def test_getattr(v0):
A = Attr()
A.v1 = "test1"
#etc
print(getattr(A, "v1"))
答案 0 :(得分:4)
getattr()
检索属性,而不是字典键,字典键是不属性。 locals()
只是另一个字典,因此将其用作一个:
print(locals()['v1'])
否则,您只能在locals()
上找到常规词典属性,例如keys
和items
以及__len__
和__getitem__
:
>>> type(locals())
<type 'dict'>
>>> dir(locals())
['__class__', '__cmp__', '__contains__', '__delattr__', '__delitem__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'clear', 'copy', 'fromkeys', 'get', 'has_key', 'items', 'iteritems', 'iterkeys', 'itervalues', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values', 'viewitems', 'viewkeys', 'viewvalues']
>>> getattr(locals(), 'keys')
<built-in method keys of dict object at 0x10028f168>