Argparse可选的位置参数?

我有一个脚本是这样使用的: usage: installer.py dir [-h] [-v]

dir是一个定义如下的位置参数:

 parser.add_argument('dir', default=os.getcwd()) 

我想要的dir是可选的:当它没有指定它应该只是cwd

不幸的是,当我不指定dir参数时,我得到Error: Too few arguments

使用nargs='?' (或者如果你需要多个目录,那么nargs='*'

 parser.add_argument('dir', nargs='?', default=os.getcwd()) 

扩展示例:

 >>> import os, argparse >>> parser = argparse.ArgumentParser() >>> parser.add_argument('-v', action='store_true') _StoreTrueAction(option_strings=['-v'], dest='v', nargs=0, const=True, default=False, type=None, choices=None, help=None, metavar=None) >>> parser.add_argument('dir', nargs='?', default=os.getcwd()) _StoreAction(option_strings=[], dest='dir', nargs='?', const=None, default='/home/vinay', type=None, choices=None, help=None, metavar=None) >>> parser.parse_args('somedir -v'.split()) Namespace(dir='somedir', v=True) >>> parser.parse_args('-v'.split()) Namespace(dir='/home/vinay', v=True) >>> parser.parse_args(''.split()) Namespace(dir='/home/vinay', v=False) >>> parser.parse_args(['somedir']) Namespace(dir='somedir', v=False) >>> parser.parse_args('somedir -h -v'.split()) usage: [-h] [-v] [dir] positional arguments: dir optional arguments: -h, --help show this help message and exit -v 

作为@VinaySajip的扩展回答。 还有更多的值得一提的 。

  1. parser.add_argument('dir', nargs=1, default=os.getcwd())

N(整数)。 来自命令行的N个参数将被汇总到一个列表中

  1. parser.add_argument('dir', nargs='*', default=os.getcwd())

'*'。 所有存在的命令行参数都被收集到一个列表中。 请注意 ,在nargs='*'有多个位置参数通常没什么意义,但是可以使用nargs='*'多个可选参数。

  1. parser.add_argument('dir', nargs='+', default=os.getcwd())

'+'。 就像'*'一样,所有存在的命令行参数都被收集到一个列表中。 此外,如果没有至less一个命令行参数,则会生成错误消息。

  1. parser.add_argument('dir', nargs=argparse.REMAINDER, default=os.getcwd())

argparse.REMAINDER 。 所有其余的命令行参数被收集到一个列表中。 这对派遣到其他命令行实用程序的命令行实用程序通常很有用

如果没有提供nargs关键字参数,则消耗的参数数量由动作决定。 通常这意味着一个命令行参数将被消耗,并且将会产生单个项目(不是列表)。

parser.add_argument需要一个开关。 你可以使用required=False 。 这是Python 2.7的示例代码片段:

 parser = argparse.ArgumentParser(description='get dir') parser.add_argument('--dir', type=str, help='dir', default=os.getcwd(), required=False) args = parser.parse_args()