在子类化不是从`object`派生的python类时使用'super'(旧式?)

时间:2010-01-07 21:52:01

标签: python

我正在使用std库模块OptionParser中的子类optparser。 (Python 2.5.2)当我尝试它时,我得到了异常:

TypeError: super() argument 1 must be type, not classobj

查看OptionParser,它不是来自object。所以我添加了object作为父类,(如下所示)和super正常工作。

from optparse import OptionParser, Option
class MyOptionParser(OptionParser, object):
    """Class to change 
    """
    def __init__(self,
             usage=None,
             option_list=None,
             option_class=Option,
             version=None,
             conflict_handler="error",
             description=None,
             formatter=None,
             add_help_option=True,
             prog=None,
             epilog=None,
            ):

      super(MyOptionParser, self).__init__(usage, option_list, option_class, version, conflict_handler, description, formatter, add_help_option, prog, epilog)

if __name__ == '__main__':
    """Run a quick test
    """
    parser = MyOptionParser()
    parser.add_option("-t", "--test", type="string", dest="test")
    (options, args) = parser.parse_args()
    print "The test option is: %s" % options.test

这是正确的方法吗?

1 个答案:

答案 0 :(得分:5)

是的,我不明白为什么它不起作用。你只需要在超级调用之前添加几个空格 - 就像现在写的那样,它不是你的自定义 init 方法的一部分。此外,您可能想要使用的快捷方式是** kwargs - 如果您希望这样做,您可以使用kwargs键检查您的方法:

class MyOptionParser(OptionParser, object):
    """Class to change 
    """
    def __init__(self, **kwargs):
        # You can limit kwargs keys here
        super(MyOptionParser, self).__init__(**kwargs)