我想定义一个字典,以便用一些助记符调用一个函数,比如run(),它调用类中的一个成员函数。所以我想出了以下内容:
class foo:
dict = { 'f_func' : f, 'g_func': g }
def f():
pass
def g():
pass
def run(self, n):
# ... do something
dict[n]()
现在问题是dict中的值是尚未定义的成员函数。我怎样才能做到这一点?
还是其他任何解决方法?
答案 0 :(得分:5)
您可以在以后定义结构,在本例中使用__init__
方法来确保您拥有绑定方法:
class foo:
def __init__(self):
self.dict = { 'f_func' : self.f, 'g_func': self.g }
def f(self):
pass
def g(self):
pass
def run(self, n):
# ... do something
self.dict[n]()
或者,按名称查找方法:
class foo:
dict = { 'f_func' : 'f', 'g_func': 'g' }
def f(self):
pass
def g(self):
pass
def run(self, n):
# ... do something
getattr(self, self.dict[n])()
在类定义完成后,您始终可以更改类:
class foo:
def f(self):
pass
def g(self):
pass
def run(self, n):
# ... do something
self.dict[n](self)
foo.dict = { 'f_func' : foo.f, 'g_func': foo.g }
但存储了未绑定的方法,强制您明确传入self
。
最后,您可以将dict
的定义移至已定义f
和g
函数的位置:
class foo:
def f(self):
pass
def g(self):
pass
dict = { 'f_func' : f, 'g_func': g }
def run(self, n):
# ... do something
self.dict[n](self)
类主体像函数一样执行,本地名称空间变为类属性。现在dict
值是函数,与未绑定方法的问题相同;你需要明确地传递self
。 (在Python 3中,没有任何未绑定的方法,此解决方案和之前的方法是等效的。)
您可能希望避免使用dict
作为属性名称,因为它可能会导致与内置dict
类型混淆。