繁体   English   中英

Python argparse - 长参数名称的帮助文本

[英]Python argparse - help text for long argument name

Python 'argparse' 在新行上显示长命名参数的帮助文本:

**#script.py -h

Select one of the options given


optional arguments:
  -h, --help            show this help message and exit
  -bs , --business_service 
                        choose the service     << New line
  -so , --service_offering 
  -ci , --cmdb_ci       provide configuration item
  -desc , --description 
                        write description     << New line

下面是我正在使用的代码:

self.parser = argparse.ArgumentParser(
            description='Select one of the options given',
            epilog=self._get_usage(),
            formatter_class=argparse.RawTextHelpFormatter
            )


        self.parser.add_argument('-bs','--business_service',type=str,help='choose the service',metavar='')
        self.parser.add_argument('-so','--service_offering',type=str,metavar='')
        self.parser.add_argument('-ci','--mdcb_ci',type=str,help='provide configuration item',metavar='')
        self.parser.add_argument('-desc','--description',type=str,help='write description',metavar='')

我希望帮助字符串位于参数的同一行:

-bs , --business_service     choose the service     << Same line

我该如何解决?

HelpFormatter class 采用max_help_position参数。 默认值为 24,这是您在帮助中看到的。

可以使用新的 Formatter 子类或修改调用参数来更改它。

In [23]: parser.formatter_class = 
    lambda prog: argparse.RawTextHelpFormatter(prog, max_help_position=30)

在这里,我修改了formatter_class属性,但您可以使用此lambda行代替

formatter_class=argparse.RawTextHelpFormatter

结果是:

In [24]: parser.print_help()
usage: ipython3 [-h] [-bs] [-so] [-ci] [-desc]

Select one of the options given

optional arguments:
  -h, --help                 show this help message and exit
  -bs , --business_service   choose the service
  -so , --service_offering 
  -ci , --mdcb_ci            provide configuration item
  -desc , --description      write description

选择这样的参数是为了平衡显示器的整体宽度和易读性。 它们可以像这样调整,但确实需要一些 Python 编程知识。 我这样做已经有一段时间了,所以我的建议可能不是最简单的。 但它通常朝着正确的方向发展。

使用partial包装器设置它的另一种方法:

In [42]: from functools import partial
In [43]: newformatter=partial(argparse.HelpFormatter, max_help_position=30)
In [44]: parser.formatter_class=newformatter

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM