usage: installer.py dir [-h] [-v]
dir
是一个位置参数,定义如下:
parser.add_argument('dir', default=os.getcwd())
我希望
dir
是可选的:当没有指定时,它应该默认为cwd
。不幸的是,当我不指定
dir
参数时,会出现Error: Too few arguments
的错误。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
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='?'
文档说:'?'。如果可能,将从命令行中消耗一个参数并作为单个项目生成。 如果没有命令行参数,则将生成默认值。
nargs='?'
并不会产生一个列表。 - Asclepiusnargs
的情况,但 nargs='?'
正在定义它。文档中提到: '?'. 如果可能的话,将从命令行中消耗一个参数,并作为单个项目生成。如果没有命令行参数,则使用默认值生成值. - Asclepiusnargs=argparse.REMAINDER
和nargs='*'
有什么区别?在我看来,它们的效果是相同的(在Python 2.7.10和Python 3.6.1中进行了测试),是否正确? - user8554766如前两个答案所示,您可以使用nargs='?'
接受可选的位置参数。如果需要,您还可以将参数直接转换为Path
类型,并将cwd缩短为.
:
myfile.py
import argparse
import pathlib
parser = argparse.ArgumentParser()
parser.add_argument("dir", nargs="?", default=".", type=pathlib.Path)
parsed_args = parser.parse_args()
print("Installing to", parsed_args.dir.resolve())
$ python myfile.py
Installing to /users/myname/myfolder
$ python myfile.py /usr/bin/
Installing to /usr/bin
既然你在问题中也提到了标志风格的True/False选项-h
和-v
,那么这些例子可能会有用:
-v
)我们可以将不带参数的可选选项称为“标志”。对于标志,我们只关心它们是否被给出。 -h
是argparse自动添加的标志(以及较长的版本--help
),因此我们不应该覆盖它。如果我们考虑-v
,则:
myfile.py
import argparse
parser = argparse.ArgumentParser()
parser.add_argument(
"-v",
"--version",
action="store_true")
parsed_args = parser.parse_args()
if parsed_args.version:
print("version flag given")
else:
print("version flag not given")
请注意,add_argument()
的第二个参数是选项的更长名称。这不是强制性的,但它确实使您后续的代码更易读(例如使用 parsed_args.version
而不是 parsed_args.v
),并使对您的安装程序的调用更加明确。
$ python myfile.py -v
version flag given
$ python myfile.py --version
version flag given
$ python myfile.py
version flag not given
--installdir /usr/bin/
)有人可能会认为,在您的情况下,使用可选参数比位置参数更好。
myfile.py
import argparse
import pathlib
parser = argparse.ArgumentParser()
parser.add_argument(
"-i",
"--installdir", # Optional (but recommended) long version
type=pathlib.Path,
default="/bin"
)
parsed_args = parser.parse_args()
print("Installing to", parsed_args.installdir)
$ python myfile.py -i /usr/bin/
Installing to /usr/bin
$ python myfile.py --installdir /usr/bin/
Installing to /usr/bin
$ python myfile.py
Installing to /bin
import argparse
import os
parser = argparse.ArgumentParser(description='Process some integers.')
parser.add_argument('-i', '--input', type=str, required=True, help='Input directory')
parser.add_argument('-o', '--output', type=str, required=True, help='Output directory')
parser.add_argument('-v', '--verbose', action='store_true', help='Enable verbose output')
args = vars(parser.parse_args())
input_dir = args['input']
output_dir = args['output']
verbose = args['verbose']
if verbose:
print('Input directory:', input_dir)
print('Output directory:', output_dir)
# Create the output directory and any necessary parent directories
os.makedirs(output_dir, exist_ok=True)
# Use input_dir and output_dir as needed
parser.add_argument
还有一个开关 required。您可以使用 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()
required
。 - Karthik Sunil
?
和*
分别表示可选的0或1个字符和0或多个字符。请问在这里提到的?
和*
是否具有相同的含义?如果是,那么+
是否也能用呢? - Dolan Antenucci+
也可以使用。详细信息请参见http://docs.python.org/2/library/argparse.html#nargs。 - Vinay Sajip