argparse - 可选参数

时间:2015-06-19 18:29:09

标签: python argparse

我正在尝试为一个脚本创建一个可选参数,该脚本可以不采用任何值或2个值,而不是其他任何值。你能用argparse做到这一点吗?

# desired output:
# ./script.py -a --> works
# ./script.py -a val1 --> error
# ./script.py -a val1 val2 --> works


版本1 - 接受0或1值:

parser = argparse.ArgumentParser()
parser.add_argument("-a", "--action", nargs="?", const=True, action="store", help="do some action")
args = parser.parse_args()

# output:
# ./script.py -a --> works
# ./script.py -a val1 --> works
# ./script.py -a val1 val2 --> error


版本2 - 正好接受2个值:

parser = argparse.ArgumentParser()
parser.add_argument("-a", "--action", nargs=2, action="store", help="do some action")
args = parser.parse_args()

# output:
# ./script.py -a --> error
# ./script.py -a val1 --> error
# ./script.py -a val1 val2 --> works


如何组合这两个不同的版本,以便脚本接受参数的0或2值,但当它只有1个值时拒绝它?

4 个答案:

答案 0 :(得分:9)

您必须在此处进行自己的错误检查。接受0或更多值,并拒绝0或2以外的任何值:

parser = argparse.ArgumentParser()
parser.add_argument("-a", "--action", nargs='*', action="store", help="do some action")
args = parser.parse_args()

if args.action is not None and len(args.action) not in (0, 2):
    parser.error('Either give no values for action, or two, not {}.'.format(len(args.action)))

请注意,如果未使用args.action开关,则None设置为-a

>>> import argparse
>>> parser = argparse.ArgumentParser()
>>> parser.add_argument("-a", "--action", nargs='*', action="store", help="do some action")
_StoreAction(option_strings=['-a', '--action'], dest='action', nargs='*', const=None, default=None, type=None, choices=None, help='do some action', metavar=None)
>>> args = parser.parse_args([])
>>> args.action is None
True
>>> args = parser.parse_args(['-a'])
>>> args.action
[]

答案 1 :(得分:4)

自己处理这个案子:

for

当然,您应该更新该案例中的帮助文本,以便用户在遇到错误之前有机会了解这一点。

答案 2 :(得分:1)

让您的选项采用单个可选的逗号分隔字符串。您将使用自定义类型将该字符串转换为列表,并验证它是否只有两个项目。

def pair(value):
    rv = value.split(',')
    if len(rv) != 2:
        raise argparse.ArgumentParser()
    return rv

parser.add_argument("-a", "--action", nargs='?',
                    type=pair, metavar='val1,val2',
                    help="do some action")
print parser.parse_args()

然后你就像

一样使用它
$ ./script.py -a
Namespace(action=None)
$ ./script.py -a val1,val2
Namespace(action=['val1','val2'])
$ ./script.py -a val1
usage: tmp.py [-h] [-a [ACTION]]
script.py: error: argument -a/--action: invalid pair value: 'val1'
$ ./script.py -a val1,val2,val3
usage: tmp.py [-h] [-a [ACTION]]
script.py: error: argument -a/--action: invalid pair value: 'val1,val2,val3'

您可以调整pair的定义以使用不同的分隔符,并返回列表以外的内容(例如,元组)。

metavar更好地表明action的参数是一对值,而不仅仅是一个。

$ ./script.py -h
usage: script.py [-h] [-a [val1,val2]]

optional arguments:
  -h, --help            show this help message and exit
  -a [val1,val2], --action [val1,val2]
                        do some action

答案 3 :(得分:-1)

所需参数如何:parser.add_argument("-a", "--action", nargs=2, action="store", help="do some action", required=False)