我在理解以下功能出了什么问题时遇到了一些麻烦:
def ness():
pie='yum'
vars()[pie]=4
print vars()[pie]
print yum
所以,当我运行时,我得到这个结果:
>>> ness()
4
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "<stdin>", line 5, in ness
NameError: global name 'yum' is not defined
如果我不把它写成一个函数,只需在命令行中输入一行就可以正常工作,就像这样:
>>> pie='yum'
>>> vars()[pie]=4
>>> print vars()[pie]
4
>>> print yum
4
>>>
编辑:
假设我想让事情比这更复杂,而不是将yum设置为值并打印该值,我定义了一些函数,并希望根据一些输入调用其中一个:
def ness(choo):
dic={}
dessert=()
dnum=[10,100]
desserts='pie'
dic[dessert]=str(desserts[bisect(dnum,choo)])
vars()[dic[dessert]]()
def p():
print 'ummmm ummm'
def i():
print 'hooo aaaaa'
def e():
print 'woooo'
因此,当我打电话给我时,我得到一个关键错误:
>>> ness(3)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "<stdin>", line 7, in ness
KeyError: 'p'
现在我知道我可以用一些elif语句做这样的事情,但是我想知道这是否也会起作用,如果像这样使用bisect会比使用elifs更有效(比如我需要检查1000个值的值) .
非常感谢您的帮助.
最佳答案 有办法用exec来做
>>> def ness():
... pie='yum'
... exec pie+"=4"
... print vars()[pie]
... print yum
...
>>>
>>> ness()
4
4
但是,不要这样做,使用新的字典更好,更安全
>>> def ness():
... dic={}
... pie='yum'
... dic[pie]=4
... print dic[pie]
... print dic['yum']
...
>>> ness()
4
4
>>>