nargs='+' 的 argparse 元变量以获取帮助信息中的编号参数?

nos*_*nos 6 python argparse

argparse 文档中,有一个使用示例nargs='+'

parser.add_argument('integers', metavar='N', type=int, nargs='+')
Run Code Online (Sandbox Code Playgroud)

对应的帮助信息是

usage: prog.py [-h] [--sum] N [N ...]
Run Code Online (Sandbox Code Playgroud)

是否可以设置metavar帮助信息看起来像这样?

usage: prog.py [-h] [--sum] N1 [N2 ...]
Run Code Online (Sandbox Code Playgroud)

hpa*_*ulj 8

metavar 可以是元组,如

In [26]: parser = argparse.ArgumentParser()
In [27]: a=parser.add_argument('--integers', metavar=('N1','N2'), type=int, nargs='+');
In [28]: parser.print_help()
usage: ipython3 [-h] [--integers N1 [N2 ...]]

optional arguments:
  -h, --help            show this help message and exit
  --integers N1 [N2 ...]
Run Code Online (Sandbox Code Playgroud)

但这仅适用于可选项(标记参数),而不适用于位置。我不确定为什么,尽管我之前可能已经研究过这个问题。

https://docs.python.org/3/library/argparse.html#metavar


有了位置,错误堆栈包括:

/usr/lib/python3.5/argparse.py in _format_action_invocation(self, action)
    542         if not action.option_strings:
    543             default = self._get_default_metavar_for_positional(action)
--> 544             metavar, = self._metavar_formatter(action, default)(1)
    545             return metavar
    546 
Run Code Online (Sandbox Code Playgroud)

Apositional没有option_strings(或它是空的),所以它使用metavar, = ...解包习语来请求一个字符串。因此错误:ValueError: too many values to unpack (expected 1)

所以期望只有一个metavar变量是故意的,但我不确定理性。也许是因为更难分辨一个位置在哪里结束,下一个在 中开始usage

In [34]: parser = argparse.ArgumentParser()
In [35]: parser.add_argument('foo', type=int, nargs=2);
In [36]: parser.add_argument('bar', type=int, nargs='+');
In [38]: parser.print_usage()
usage: ipython3 [-h] foo foo bar [bar ...]
Run Code Online (Sandbox Code Playgroud)

几年前我看过这个,https://bugs.python.org/issue14074。看起来usage,帮助热线和错误消息可能存在问题。


实际上问题不在于usage,而在于格式化帮助行:

In [39]: parser = argparse.ArgumentParser()
In [40]: a=parser.add_argument('integers', metavar=('N1','N2'), type=int, nargs='+')
In [41]: parser.print_usage()
usage: ipython3 [-h] N1 [N2 ...]
Run Code Online (Sandbox Code Playgroud)

位置的正常帮助行只显示一个符号,而不是N [N ...]用法:

In [43]: parser.print_help()
usage: ipython3 [-h] N [N ...]

positional arguments:
  N
Run Code Online (Sandbox Code Playgroud)