23

我一直在为要完成的这一小块活动而烦恼。我确实做了一些实验,但无法达到结果。

要求:

   test2.py [-c/-v] -f

用法或规则:

  1. -c (比较)采用 2 个参数。

    -v(验证)采用 1 个参数。

    这两者中的任何一个都必须存在,但不能同时存在。

  2. -f 是强制参数(输出文件名)。

输出:

我能够获得所需的输出,如下所示

kp@kp:~/Study/scripts$ ./test.py -c P1 P2 -f p
kp@kp:~/Study/scripts$ ./test.py -v P1 -f p
kp@kp:~/Study/scripts$ ./test.py -v P1 
usage: test.py <functional argument> <ouput target argument>
test.py: error: argument -f/--file is required
kp@kp:~/Study/scripts$ ./test.py -c P1 P2 
usage: test.py <functional argument> <ouput target argument>
test.py: error: argument -f/--file is required
kp@kp:~/Study/scripts$ 

问题是:

当您使用时,test.py -h,
1.输出不会表明 -c/-v其中任何一个是强制性的,但不是两者都是。它表示所有参数都是可选的。
2. 输出将指示可选参数下的-f 选项不正确。-f 是强制参数,我想在外面显示 - 可选参数。

如何更改脚本以使 -h 选项输出对用户更友好(无需任何外部验证)

usage: test.py <functional argument> <ouput target argument>

Package Compare/Verifier tool.

optional arguments:
  -h, --help            show this help message and exit
  -f outFileName, --file outFileName
                        File Name where result is stored.
  -c Package1 Package2, --compare Package1 Package2
                        Compare two packages.
  -v Package, --verify Package
                        Verify Content of package.
kiran@kiran-laptop:~/Study/scripts$ 

代码:

我正在使用下面的代码来实现输出,

#!/usr/bin/python

import sys
import argparse

def main():
    usage='%(prog)s <functional argument> <ouput target argument>'
    description='Package Compare/Verifier tool.'
    parser = argparse.ArgumentParser(usage=usage,description=description)

    parser.add_argument('-f','--file',action='store',nargs=1,dest='outFileName',help='File Name where result is stored.',metavar="outFileName",required=True)


    group = parser.add_mutually_exclusive_group(required=True)
    group.add_argument('-c','--compare',action='store',nargs=2,dest='packageInfo',help='Compare two packages.',metavar=("Package1","Package2"))
    group.add_argument('-v','--verify',action='store',nargs=1,dest='packageName',help='Verify Content of package.',metavar='Package')
    args = parser.parse_args()

if __name__ == "__main__":
    main()
4

3 回答 3

28

将文件名设置为位置参数,并argparse设置自己的使用消息:

$ python so.py --help
usage: so.py [-h] [-c Package1 Package2 | -v Package] outFileName

文件名应该是位置的,你应该让argparse写它自己的使用信息。

代码

#!/usr/bin/python

import sys
import argparse

def main():
    description='Package Compare/Verifier tool.'
    parser = argparse.ArgumentParser(description=description,
                                     epilog='--compare and --verify are mutually exclusive')

    parser.add_argument('f',action='store',nargs=1,
                        help='File Name where result is stored.',
                        metavar="outFileName")

    group = parser.add_mutually_exclusive_group(required=False)
    group.add_argument('-c','--compare',action='store',nargs=2,dest='packageInfo',help='Compare two packages.',metavar=("Package1","Package2"))
    group.add_argument('-v','--verify',action='store',nargs=1,dest='packageName',help='Verify Content of package.',metavar='Package')

    args = parser.parse_args()

if __name__ == "__main__":
    main()

帮助信息

$ python so.py --help
usage: so.py [-h] [-c Package1 Package2 | -v Package] outFileName

Package Compare/Verifier tool.

positional arguments:
  outFileName           File Name where result is stored.

optional arguments:
  -h, --help            show this help message and exit
  -c Package1 Package2, --compare Package1 Package2
                        Compare two packages.
  -v Package, --verify Package
                        Verify Content of package.

--compare and --verify are mutually exclusive
于 2011-04-09T06:59:23.280 回答
11

你在寻找什么确切的输出?我不知道在 --help 输出中表示互斥性的任何标准语法,如果你编造一个,它可能会让你的用户感到困惑。另外我假设 argparse 不支持它的语法(因为如果支持,它已经可以工作了)。

我建议您保持简单,只需向您的用户解释每个参数的帮助中的互斥。所以改变他们的帮助字符串如下:

-c Package1 Package2, --compare Package1 Package2
                      Compare two packages (may not be used with -v).
-v Package, --verify Package
                      Verify Content of package (may not be used with -c).

这是非常明显且相当简洁的。

另一种选择是不提它,让用户通过尝试同时使用它们来发现它们是互斥的(argparse 会自动生成一个用户友好的错误,例如“ PROG: error: argument -c: not allowed with argument -v”)。

于 2011-04-09T07:07:31.013 回答
4

我认为基本的抱怨是默认positional argumentsoptional arguements组名。在 中helpoptional arguments表示:requires a flag like -f or --file; positional arguments意味着it is identified by position。对于默认值,positionals确实是必需的,并且optionals确实是可选的(不是必需的)。但是用户可以用一个required属性来改变它,从而引起混淆的术语。

解决此问题的一种方法是定义您自己的参数组。这些组影响 的布局help,但对解析没有影响。它们也不影响usage线路。

def main():
    description='Package Compare/Verifier tool.'
    parser = argparse.ArgumentParser(usage=None,description=description)

    maingroup = parser.add_argument_group(title='required')
    maingroup.add_argument('-f','--file',nargs=1,dest='outFileName',help='File Name where result is stored.',metavar="outFileName",required=True)
    exgroup = parser.add_argument_group(title='one or the other')

    group = exgroup.add_mutually_exclusive_group(required=True)
    group.add_argument('-c','--compare',nargs=2,dest='packageInfo',help='Compare two packages.',metavar=("Package1","Package2"))
    group.add_argument('-v','--verify',nargs=1,dest='packageName',help='Verify Content of package.',metavar='Package')
    args = parser.parse_args()

产生:

usage: stack5603364.py [-h] -f outFileName (-c Package1 Package2 | -v Package)

Package Compare/Verifier tool.

optional arguments:
  -h, --help            show this help message and exit

required:
  -f outFileName, --file outFileName
                        File Name where result is stored.

one or the other:
  -c Package1 Package2, --compare Package1 Package2
                        Compare two packages.
  -v Package, --verify Package
                        Verify Content of package.

mutually_exclusive_group仅影响usage线路。

(-c Package1 Package2 | -v Package)

显示需要其中一个选项的组。

[-c Package1 Package2 | -v Package]

将是一个可选组。 []用于标记可选(在“不需要”的意义上)参数。请注意如何-h继续标记。

http://bugs.python.org/issue9694是相关的 Python 问题,argparse作者赞成这种argument_group方法。

于 2013-11-22T16:53:45.403 回答