使用argparse
under python3
,我试图以自定义方式设置子解析器帮助文本和子解析器帮助文本。以下示例程序说明了我的问题(示例程序的源代码出现在此消息的底部)。该示例程序应按如下方式运行:
argtest cmd [ ... args ... ]
或者
argtest special subcmd [ ... args ... ]
“cmd”可以是“cmd00”、“cmd01”等,“subcmd”可以是“sub00”、“sub01”等。
当我运行它时argtest cmd00 -h
,我想获得“cmd00”命令的具体帮助。当我运行它时argtest special sub00 -h
,我想获得“sub00”特殊命令的具体帮助。
但是,我没有得到这些帮助值。鉴于下面的代码,当我运行此命令时:
% argtest special -h
...我得到这个输出:
usage: argtest (toplevel) special [-h] [--debug] {sub00,sub01} ...
positional arguments:
{sub00,sub01}
sub00 sub00 toplevel help
sub01 sub01 toplevel help
optional arguments:
-h, --help show this help message and exit
--debug
但是,我想要的是以下内容:
special toplevel help
positional arguments:
{sub00,sub01}
sub00 sub00 toplevel help
sub01 sub01 toplevel help
optional arguments:
-h, --help show this help message and exit
--debug
同样,当我运行它时:
% argtest special sub00 -h
...我得到这个输出:
usage: argtest (toplevel) special sub00 [-h] [--debug] [--sub0 SUB0]
optional arguments:
-h, --help show this help message and exit
--debug
--sub0 SUB0 sub0-help
但是,我想要这个:
sub00 toplevel help
optional arguments:
-h, --help show this help message and exit
--debug
--sub0 SUB0 sub0-help
似乎较低级别的帮助值被忽略了,并且帮助总是强制使用顶层的默认帮助,然后为所有子解析器生成帮助。
鉴于我正在使用嵌套子子解析器的子解析器,有什么方法可以获得我想要的帮助消息?非常感谢。
这是示例程序:
#!/usr/bin/python3
import os
import sys
import argparse
prog = None
def main():
parser = argparse.ArgumentParser(usage=f'{prog} (toplevel)')
parser.add_argument(
'--verbose',
dest='VERBOSE',
action='store_true',
help='verbose output'
)
globalopts = argparse.ArgumentParser(add_help=False)
globalopts.add_argument(
'--debug',
dest='DEBUG',
action='store_true'
)
command = parser.add_subparsers(
dest='CMD',
help=f'{prog} CMD [ ... args ... ]'
)
command_00 = command.add_parser('cmd00',
parents=[globalopts], help='cmd00 toplevel help')
command_00.add_argument('--a', dest='A',
default=None, required=0, help='cmd00-a-help')
command_01 = command.add_parser('cmd01',
parents=[globalopts], help='cmd01 toplevel help')
command_01.add_argument('--b', dest='B',
default=None, required=0, help='cmd00-b-help')
# etc. ... lots of others, up to up to command_99
special = command.add_parser('special',
parents=[globalopts], add_help='special toplevel help')
subparsers = special.add_subparsers(dest='SUBPARSERS')
special_00 = subparsers.add_parser('sub00',
parents=[globalopts], help='sub00 toplevel help')
special_00.add_argument('--sub0', dest='SUB0',
default=None, required=0, help='sub0-help')
special_01 = subparsers.add_parser('sub01',
parents=[globalopts], help='sub01 toplevel help')
special_01.add_argument('--sub1', dest='SUB1',
default=None, required=0, help='sub1-help')
args, unknowns = parser.parse_known_args()
print(f'args={vars(args)}')
return 0
if __name__ == '__main__':
prog = os.path.basename(sys.argv[0])
sys.exit(main())