为什么在添加子解析器时继承 ArgumentParser 会导致 TypeError
Why does inheritation of ArgumentParser cause TypeError when adding subparsers
为什么下面的代码会出问题?
意图:我想提取工具套件中工具参数解析器之间的公共选项和清理代码。
编辑:我想向构造函数添加其他参数。
import argparse
class MyParser(argparse.ArgumentParser):
def __init__(self):
super().__init__()
def parse_args(self):
return super().parse_args()
if __name__=="__main__":
parser = MyParser()
subparsers = parser.add_subparsers()
subparsers.add_parser("create", help="Create something...")
Traceback (most recent call last):
File "custom-argparser.py", line 13, in <module>
subparsers.add_parser("create", help="Create something...")
File "C:\Program Files\Python38\lib\argparse.py", line 1123, in add_parser
parser = self._parser_class(**kwargs)
TypeError: __init__() got an unexpected keyword argument 'prog'
您需要更改 __init__
输入参数
更新您的代码如下
def __init__(self, *args, **kwargs):
super().__init__()
新更新:
第二个最简单的选项是不定义 __init__
,因为它只会继承其父定义。
class MyParser(argparse.ArgumentParser):
def parse_args(self):
return super().parse_args()
这是一个首选选项,原因是,在重新定义 __init__
时,您需要了解您在自定义 class水平,然后你需要理解并将它们传递给super().__init__()
。
如果您希望包含一些额外的参数,那么定义 __init__
是通常遵循的标准方法。否则,保持简单
为什么下面的代码会出问题?
意图:我想提取工具套件中工具参数解析器之间的公共选项和清理代码。
编辑:我想向构造函数添加其他参数。
import argparse
class MyParser(argparse.ArgumentParser):
def __init__(self):
super().__init__()
def parse_args(self):
return super().parse_args()
if __name__=="__main__":
parser = MyParser()
subparsers = parser.add_subparsers()
subparsers.add_parser("create", help="Create something...")
Traceback (most recent call last):
File "custom-argparser.py", line 13, in <module>
subparsers.add_parser("create", help="Create something...")
File "C:\Program Files\Python38\lib\argparse.py", line 1123, in add_parser
parser = self._parser_class(**kwargs)
TypeError: __init__() got an unexpected keyword argument 'prog'
您需要更改 __init__
输入参数
更新您的代码如下
def __init__(self, *args, **kwargs):
super().__init__()
新更新:
第二个最简单的选项是不定义 __init__
,因为它只会继承其父定义。
class MyParser(argparse.ArgumentParser):
def parse_args(self):
return super().parse_args()
这是一个首选选项,原因是,在重新定义 __init__
时,您需要了解您在自定义 class水平,然后你需要理解并将它们传递给super().__init__()
。
如果您希望包含一些额外的参数,那么定义 __init__
是通常遵循的标准方法。否则,保持简单