我正在使用OptionParserstd库模块的子类化optparser.(Python 2.5.2)当我尝试它时,我得到了异常:
TypeError: super() argument 1 must be type, not classobj
Run Code Online (Sandbox Code Playgroud)
看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
Run Code Online (Sandbox Code Playgroud)
这是正确的方法吗?
是的,我不明白为什么它不起作用.你只需要在超级调用之前添加几个空格 - 就像现在写的那样,它不是你的自定义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)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
360 次 |
| 最近记录: |