docopt 模块(参数解析器)的行为



我目前是第一次使用docopt库,所以我肯定做错了什么

我的脚本是:

"""prog
Usage:
    prog.py (-h | --help)
    prog.py (--version)
    prog.py -s TAG [-t NB_NUC]
Options:
    -h, --help   help
    --version    version
    -s TAG       Some TAG I want.
    -t NB_NUC    A number of nuc.
"""

如果我写: python prog.py -s SMT

我得到:

{'--help': False,
    '--version': False,
    '-h': False,
    '-s': True,
    '-t': True,
    'NB_NUC': None,
    'TAG': 'SMT'}

这似乎是正确的,但是如果我写:

python prog.py -s -t 10 -> TAG contain 10 (instead of None)
python prog.py -t 10 -s SMT -> TAG contain always 10 (instead of SMT) and NB_NUC contain SMT (instead of 10)
python prog.py -s SMT -t -> TAG contain SMT and NB_NUC contain None (and its what I expected on this way)

所以,我尝试了很多组合,但我不明白这应该如何措辞......

我想要的是 TAG 始终包含与 -s 参数对应的值,如果 -s 之后没有给出任何内容,则为 None 或错误,我不明白为什么不是这样。.

感谢您的帮助!

你快到了,只需要参数周围的"<...>":

"""prog
Usage:
    prog.py (-h | --help)
    prog.py (--version)
    prog.py -s TAG [-t NB_NUC]
Options:
    -h, --help   help
    --version    version
    -s TAG       Some TAG I want.
    -t NB_NUC    A number of nuc.
"""

问题来自这样一个事实,即以前版本的docopt不适用于表格缩进。实际版本确实如此,PEP8 建议无论如何使用空格。

对于格式化,最简单的方法是只写

Usage:
    prog.py (-h | --help)
    prog.py (-v | --version)
    prog.py [options] <mandatory_file>

并将不同的选项及其描述放在Options部分中。

相关内容

  • 没有找到相关文章

最新更新