将 argparse 用于不带前缀的强制参数
Using argparse for mandatory argument without prefix
我正在尝试在我的 python 应用程序中使用 argparse 模块。
我的应用程序应该是 运行,只有一个强制参数,没有任何前缀。我想不出办法。
这是一个简单的例子,使用 argparse 只需要一个整数参数:
import argparse
parser = argparse.ArgumentParser(description='process an integer')
parser.add_argument('integer', metavar='N', type=int, nargs=1,
help='an integer')
args = parser.parse_args()
print(args.integer)
将此代码保存在 argparse1.py 和 运行 中,得到:
$ python argparse1.py 5
[5]
$ python argparse1.py
usage: argparse1.py [-h] N
argpars1.py: error: the following arguments are required: N
$ python argparse1.py 5 7
usage: argparse1.py [-h] N
argparse1.py: error: unrecognized arguments: 7
$ python argparse1.py test
usage: argparse1.py N
argparse1.py: error: argument N: invalid int value: 'test'
$ python argparse1.py -h
usage: argparse1.py [-h] N
process an integer
positional arguments:
N an integer
optional arguments:
-h, --help show this help message and exit
要删除可选参数,请使用 add_help=False 定义 ArgumentParser,如下所示:
import argparse
parser = argparse.ArgumentParser(add_help=False)
parser.add_argument('integer', metavar='N', type=int, nargs=1)
args = parser.parse_args()
print(args.integer)
将此代码放入 argparse2.py 并对其进行测试:
$ python argparse2.py
usage: argparse2.py N
argparse2.py: error: the following arguments are required: N
$ python argparse2.py 5
[5]
$ python argparse2.py 5 7
usage: argparse2.py N
argparse2.py: error: unrecognized arguments: 7
$ python argparse2.py hello
usage: argparse2.py N
argparse2.py: error: argument N: invalid int value: 'hello'
$ python argparse2.py -h
usage: argparse2.py N
argparse2.py: error: the following arguments are required: N
可以通过导入 argparse.SUPPRESS 并使用 usage=SUPPRESS 配置 ArgumentParser 来抑制所有用法消息,如下所示:
from argparse import ArgumentParser,SUPPRESS
parser = ArgumentParser(add_help=False, usage=SUPPRESS)
parser.add_argument('integer', metavar='N', type=int, nargs=1)
args = parser.parse_args()
print(args.integer)
将此代码保存在 argparse3.py 和 运行 中得到:
$ python argparse3.py 5
[5]
$ python argparse3.py 5 7 9
argparse3.py: error: unrecognized arguments: 7 9
$ python argparse3.py -h
argparse3.py: error: the following arguments are required: N
"unrecognized arguments" 错误被硬编码在 ArgumentParser.parse_args() (https://hg.python.org/cpython/file/3.4/Lib/argparse.py#l1727) and the "following arguments are required" error is separately hardcoded (https://hg.python.org/cpython/file/3.4/Lib/argparse.py#l1994) 中,两者都没有求助于 API 的修改。后者似乎在 _parse_known_args(self, arg_strings, namespace) 中,我认为它可以被覆盖,但会涉及复制大约 250 行代码以修改 1 行以更改该错误消息。
但是,可以通过仅添加一个带 nargs='*' 且不带类型的参数来避免这些错误消息,这样可以有效地允许所有命令行,然后添加参数的自定义错误处理,包括您自己的错误和使用消息。例如:
import os
import sys
from argparse import ArgumentParser,SUPPRESS
script = os.path.basename(sys.argv[0])
usage = 'usage: ' + script + ' n (int)'
parser = ArgumentParser(add_help=False, usage=SUPPRESS)
parser.add_argument('integer', nargs='*')
args = parser.parse_args()
if (len(args.integer) == 0):
print('error: no argument provided\n', usage, file=sys.stderr, sep = '')
sys.exit(1)
if (len(args.integer) > 1):
print('error: too many arguments\n', usage, file=sys.stderr, sep = '')
sys.exit(1)
v = args.integer[0]
try:
v = int(v)
except ValueError:
print("error: '", v, "'", ' is not an integer\n', usage, file=sys.stderr, sep='')
sys.exit(1)
print(v + 2)
将此代码放入 argparse4.py 并对其进行测试:
$ python argparse4.py 5
7
$ python argparse4.py
error: no argument provided
usage: argparse4.py n (int)
$ python argparse4.py 5 9
error: too many arguments
usage: argparse4.py n (int)
$ python argparse4.py hello
error: 'hello' is not an integer
usage: argparse4.py n (int)
您只需像这样定义参数:
parser.add_argument("x")
不要在x
前加任何-
。
我正在尝试在我的 python 应用程序中使用 argparse 模块。 我的应用程序应该是 运行,只有一个强制参数,没有任何前缀。我想不出办法。
这是一个简单的例子,使用 argparse 只需要一个整数参数:
import argparse
parser = argparse.ArgumentParser(description='process an integer')
parser.add_argument('integer', metavar='N', type=int, nargs=1,
help='an integer')
args = parser.parse_args()
print(args.integer)
将此代码保存在 argparse1.py 和 运行 中,得到:
$ python argparse1.py 5
[5]
$ python argparse1.py
usage: argparse1.py [-h] N
argpars1.py: error: the following arguments are required: N
$ python argparse1.py 5 7
usage: argparse1.py [-h] N
argparse1.py: error: unrecognized arguments: 7
$ python argparse1.py test
usage: argparse1.py N
argparse1.py: error: argument N: invalid int value: 'test'
$ python argparse1.py -h
usage: argparse1.py [-h] N
process an integer
positional arguments:
N an integer
optional arguments:
-h, --help show this help message and exit
要删除可选参数,请使用 add_help=False 定义 ArgumentParser,如下所示:
import argparse
parser = argparse.ArgumentParser(add_help=False)
parser.add_argument('integer', metavar='N', type=int, nargs=1)
args = parser.parse_args()
print(args.integer)
将此代码放入 argparse2.py 并对其进行测试:
$ python argparse2.py
usage: argparse2.py N
argparse2.py: error: the following arguments are required: N
$ python argparse2.py 5
[5]
$ python argparse2.py 5 7
usage: argparse2.py N
argparse2.py: error: unrecognized arguments: 7
$ python argparse2.py hello
usage: argparse2.py N
argparse2.py: error: argument N: invalid int value: 'hello'
$ python argparse2.py -h
usage: argparse2.py N
argparse2.py: error: the following arguments are required: N
可以通过导入 argparse.SUPPRESS 并使用 usage=SUPPRESS 配置 ArgumentParser 来抑制所有用法消息,如下所示:
from argparse import ArgumentParser,SUPPRESS
parser = ArgumentParser(add_help=False, usage=SUPPRESS)
parser.add_argument('integer', metavar='N', type=int, nargs=1)
args = parser.parse_args()
print(args.integer)
将此代码保存在 argparse3.py 和 运行 中得到:
$ python argparse3.py 5
[5]
$ python argparse3.py 5 7 9
argparse3.py: error: unrecognized arguments: 7 9
$ python argparse3.py -h
argparse3.py: error: the following arguments are required: N
"unrecognized arguments" 错误被硬编码在 ArgumentParser.parse_args() (https://hg.python.org/cpython/file/3.4/Lib/argparse.py#l1727) and the "following arguments are required" error is separately hardcoded (https://hg.python.org/cpython/file/3.4/Lib/argparse.py#l1994) 中,两者都没有求助于 API 的修改。后者似乎在 _parse_known_args(self, arg_strings, namespace) 中,我认为它可以被覆盖,但会涉及复制大约 250 行代码以修改 1 行以更改该错误消息。
但是,可以通过仅添加一个带 nargs='*' 且不带类型的参数来避免这些错误消息,这样可以有效地允许所有命令行,然后添加参数的自定义错误处理,包括您自己的错误和使用消息。例如:
import os
import sys
from argparse import ArgumentParser,SUPPRESS
script = os.path.basename(sys.argv[0])
usage = 'usage: ' + script + ' n (int)'
parser = ArgumentParser(add_help=False, usage=SUPPRESS)
parser.add_argument('integer', nargs='*')
args = parser.parse_args()
if (len(args.integer) == 0):
print('error: no argument provided\n', usage, file=sys.stderr, sep = '')
sys.exit(1)
if (len(args.integer) > 1):
print('error: too many arguments\n', usage, file=sys.stderr, sep = '')
sys.exit(1)
v = args.integer[0]
try:
v = int(v)
except ValueError:
print("error: '", v, "'", ' is not an integer\n', usage, file=sys.stderr, sep='')
sys.exit(1)
print(v + 2)
将此代码放入 argparse4.py 并对其进行测试:
$ python argparse4.py 5
7
$ python argparse4.py
error: no argument provided
usage: argparse4.py n (int)
$ python argparse4.py 5 9
error: too many arguments
usage: argparse4.py n (int)
$ python argparse4.py hello
error: 'hello' is not an integer
usage: argparse4.py n (int)
您只需像这样定义参数:
parser.add_argument("x")
不要在x
前加任何-
。