Python MRO并通过super()传递kwargs

时间:2013-06-27 18:22:01

标签: python multiple-inheritance method-resolution-order

我在Ubuntu 13.04上使用Python 2.7。我正在构建一系列计划任务,将一些数据上传到第三方API。我正在尝试以通用方式构建任务,以便我们以后可以轻松添加更多。在这样做的过程中,我使用了一些不按预期方式工作的继承技术。我认为MRO非常简单,但我必须做错事,因为我在尝试初始化任务时得到global name 'UpdateBase' is not defined

以下是我正在使用的继承结构。

class UpdateBase(PeriodicTask):
    def __init__(self, table_type=None, update_type=constants.UPDATE_REALTIME,
                 cache_time=constants.CACHE_TIME_UPDATE):
        super(UpdateBase, self).__init__()
        self.table_type = table_type
        self.update_type = update_type
        self.cache_time = cache_time
        self.filename = '{}-{}.{}'.format(
            table_type, datetime.datetime.now(), self.update_type)
        self.old_files = '{}-*'.format(table_type)
        self.file_path = os.path.join(
            constants.UPDATE_FILE_PATH, self.filename)


class UpdateAffiliates(UpdateBase):
    def __init__(self, **kwargs):
        super(UpdateAffiliates, self).__init__(
            table_type=constants.AFFILIATES, **kwargs)


class OverlapAffiliates(UpdateAffiliates):
    def __init__(self, **kwargs):
        super(OverlapAffiliates, self).__init__(
            update_type=constants.UPDATE_OVERLAP,
            cache_time=constants.UPDATE_OVERLAP, **kwargs)

有关为何我收到此错误的任何建议?

EDIT1:

似乎还有其他因素导致NameError。我已经构建了几个测试这个MRO的层次结构。我已经测试了我能想到的每一种方式,一切都很好。如果有人能想到任何我可以检查,更改或包含的内容,我会很感激。

测试代码的一个例子:

#!/usr/bin/env python

CONST1 = 'const_1'
CONST2 = 'const_2'
CONST3 = 'const_3'


class Test1(object):
    internal_val = 'internal 1'

    def __init__(self, val1=None, val2=CONST2, val3=CONST3):
        print 'val1: {}\nval2: {}\nval3: {}\ninternal_val: {}'.format(
            val1, val2, val3, self.internal_val)


class Test2(Test1):
    def __init__(self, **kwargs):
        super(Test2, self).__init__(val1=CONST1, **kwargs)


class Test3(Test2):
    internal_val = 'internal 3'

    def __init__(self, **kwargs):
        super(Test3, self).__init__(
            val2='test3 val2', val3='test3 val3', **kwargs)


def main():
    test1 = Test1()
    test2 = Test2()
    test3 = Test3()

if __name__ == '__main__':
    main()

1 个答案:

答案 0 :(得分:0)

我能够通过放弃在__init__()方法中进行初始化来解决我的问题。相反,我使用了基础setup_info()方法。我在基地举起NotImplementedError并在每个孩子中写下设置。没什么大不了的,但不是那么优雅。 :)

我仍然想知道这个问题的根本原因是什么。我是从芹菜PeriodicTask继承而来的。没什么好看的。