我有一个脚本,打算像这样使用:
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 答案的扩展。还有额外的nargs
值得一提。
parser.add_argument('dir', nargs=1, default=os.getcwd())
N(整数)。来自命令行的 N 个参数将被收集到一个列表中
parser.add_argument('dir', nargs='*', default=os.getcwd())
'*'。存在的所有命令行参数都收集到一个列表中。请注意,使用 具有多个位置参数通常没有多大意义nargs='*'
,但可以使用多个可选参数nargs='*'
。
parser.add_argument('dir', nargs='+', default=os.getcwd())
'+'。就像“*”一样,所有存在的命令行参数都被收集到一个列表中。此外,如果不存在至少一个命令行参数,则会生成一条错误消息。
parser.add_argument('dir', nargs=argparse.REMAINDER, default=os.getcwd())
argparse.REMAINDER
. 所有剩余的命令行参数都被收集到一个列表中。这对于调度到其他命令行实用程序的命令行实用程序通常很有用
如果nargs
未提供关键字参数,则使用的参数数量由操作确定。通常这意味着将使用单个命令行参数并生成单个项目(不是列表)。
编辑(从@Acumenus 的评论中复制) 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()