如何定义依赖于尚未定义的数据结构?

时间:2013-04-16 10:36:42

标签: python

我想定义一个字典,以便用一些助记符调用一个函数,比如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中的值是尚未定义的成员函数。我怎样才能做到这一点?

还是其他任何解决方法?

1 个答案:

答案 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的定义移至已定义fg函数的位置:

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类型混淆。