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

אבר*_*ובו 3 python command-line-arguments argparse

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
Run Code Online (Sandbox Code Playgroud)

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

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='')
Run Code Online (Sandbox Code Playgroud)

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

-bs , --business_service     choose the service     << Same line
Run Code Online (Sandbox Code Playgroud)

我该如何解决?

hpa*_*ulj 5

全班HelpFormatter进行max_help_position辩论。默认值是 24,这是您在帮助中看到的。

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

In [23]: parser.formatter_class = 
    lambda prog: argparse.RawTextHelpFormatter(prog, max_help_position=30)
Run Code Online (Sandbox Code Playgroud)

在这里,我要修改formatter_class之后的属性,但您可以使用这一lambda行代替

formatter_class=argparse.RawTextHelpFormatter
Run Code Online (Sandbox Code Playgroud)

结果是:

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
Run Code Online (Sandbox Code Playgroud)

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

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

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