- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写一个 python 命令行客户端程序来与 api 交互。用户使用客户端程序运行以下命令,客户端程序对 api 进行以下示例调用
python run.py --car --> calls method get_all(vehicle_type) which requests--> /car/all --< which returns list of all cars
python run.py --van --> /van/all --> which returns list of all vans
/car/id/123 --> --> calls method get_by_id(vehicle_type, id) which requests --> returns list of car with id 123
其他人也类似。
/car/color/red return list of car with color red
/car/model_no/31x return car with model_no 31x
/van/id/312 returns list of van with id 321
我正在使用 arg parse 来达到此目的,但无法正确放置它。现在,我正在做。
parser = argparse.ArgumentParser()
grp1 = parser.add_mutually_exclusive_group(required=True)
grp2 = parser.add_mutually_exclusive_group()
grp1.add_argument('--car', action='store_const', const='car')
grp1.add_argument('--van', action='store_const', const='van')
grp2.add_argument('--id', help='get by id')
grp2.add_argument('--model_no', help='get by model number')
grp2.add_argument('--color', help='get by color')
arg_dict = {k:v for k, v in vars(args).items() if v}
当我运行此代码作为命令时。
python run.py --car --id 123
我明白了
{'car' : 'car' , 'id' : '123'}
我正在循环遍历这个字典并使用 getattr 通过键名称 'get_by_{name}'.format(name = key) 调用函数。但是,我的代码看起来不太好,因为我必须检查长度是否为 1,然后调用 get all 函数并检查车辆类型。有没有更好的方法来正确使用argparse,使代码更加紧凑。
最佳答案
(我认为)做你想做的事情的一个相对直接的方法是:
import argparse
def get_all(vehicle_type, *value): # optional value parameter
print('all', vehicle_type)
def get_by_id(vehicle_type, id):
print('id', vehicle_type, id)
def get_by_color(vehicle_type, color):
print('color', vehicle_type, color)
def get_by_model(vehicle_type, model):
print('model', vehicle_type, model)
parser = argparse.ArgumentParser()
parser.add_argument('--vehicle_type','-v',choices=['car','van'])
# could be mutually exclusive group with --car and --var
getby_group = parser.add_mutually_exclusive_group()
getby_group.add_argument('--id')
getby_group.add_argument('--color')
getby_group.add_argument('--model')
args = parser.parse_args()
if args.id:
get_by_id(args.vehicle_type, args.id)
elif args.color:
get_by_color(args.vehicle_type, args.color)
elif args.model:
get_by_model(args.vehicle_type, args.model)
else:
get_all(args.vehicle_type)
您可以使用 default=argparse.SUPPRESS
将 id
保留在 args
之外(就像您对 arg_dict = { 所做的那样) k:v for k, v in vars(args).items() if v}
。但更容易测试
if args.id:
...
比
if hasattr(args,'id'):
...
或
if get(vars,'id',None):
...
如果您确实想从 args 值生成函数名称,您可以进行字典查找(locals()
或自定义字典)。在内部,argparse
通过 parser.register
使用 registries
字典。
fn = locals().get('get_by_%s'%'id')
fn(args.vehicle_type, args.id)
argparse
文档展示了如何使用 parser.set_defaults
将 args
属性定义为函数。但这种特殊用途仅适用于子解析器。
您可以使用const
来设置函数,例如
getby_group.add_argument('--id',dest='fn',action='store_const', const=get_by_id)
然后
args.fn(...)
将运行get_by_id
函数。
<删除了使用此store_const
的版本。它在接受某个值时遇到了问题;设置详细编辑历史记录 >
====================
这是定义 fn
属性和 值
的自定义操作方法
class GetAction(argparse._StoreAction):
# barest customization
def __init__(self, *args, **kwargs):
fn=kwargs.pop('fn')
super(GetAction, self).__init__(*args, **kwargs)
self.fn = fn
def __call__(self, parser, namespace, values, option_string=None):
super(GetAction, self).__call__(parser, namespace, values, option_string=None)
setattr(namespace, 'fn', self.fn)
parser.set_defaults(fn=get_all) # default action
getby_group.add_argument('--id', dest='value', action=GetAction, fn=get_by_id)
getby_group.add_argument('--color',dest='value', action=GetAction, fn=get_by_color)
getby_group.add_argument('--model',dest='value', action=GetAction, fn=get_by_model)
args = parser.parse_args()
args.fn(args.vehicle_type, args.value)
但是 - 请注意,类定义需要比 if-else
树更多的代码行。我花了更长的时间来写。
关于python - 使用 argparse 的建议,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37534352/
我正在尝试使用 parser = argparse.ArgumentParser对于我写的一个小程序。 程序接受作为输入 EITHER ( txt 文件的路径 ) OR ( opt1 && opt2
我为需要遵循特定格式的参数定义了自定义正则表达式类型。我使用了另一篇文章 ( regex custom type ) 中的代码,它非常有用。我的问题是我正在编写单元测试,我希望正则表达式失败并尝试断言
我写了下面的代码。 import argparse parser = argparse.ArgumentParser() parser.add_argument('-v', '--version',
我一定遗漏了一些明显的东西。目标是使用 argparse,第一个参数是必需的,第二个是可选的,其他任何剩余参数都是可选的。 为了展示这个问题,我制作了两个测试解析器;它们之间的唯一区别是在一个中使用
我正在努力寻找一种将参数传递给 docker container 中的 python 脚本的方法。基于ubuntu 。我正在与docker-compose.yml合作. 请查看下面的示例! docke
我正在努力寻找一种将参数传递给 docker container 中的 python 脚本的方法。基于ubuntu 。我正在与docker-compose.yml合作. 请查看下面的示例! docke
我像这样创建一个 argparser: parser = argparse.ArgumentParser(description='someDesc') parser.add_argument
我正在编写一个脚本,其中包含 2 个相互排斥的参数,以及一个仅对其中一个参数有意义的选项。如果您使用毫无意义的参数调用它,我会尝试将 argparse 设置为失败。 要清楚: -m -f 有意义 -s
我正在使用 Python 3.6 和 argparse 1.1。 除了 -h/--help 我还想有一个选项 -v/--version打印带有版本信息的字符串并退出程序(就像使用帮助字符串一样)。但是
有没有办法将来自父解析器的参数分组到不同的组中?我无权访问父解析器本身,所以我不能在那里添加组。 (我使用的是 Google 的 OAuth2 框架)。 目前我的代码是: # test.py from
GNU grep 有一个参数可以在匹配行周围打印一定数量的额外行。从手册页: -C NUM, -NUM, --context=NUM Print NUM lines of output context
现在,我有一个脚本可以使用 argparse 接受命令行参数。例如,像这样: #foo.py def function_with_args(optional_args=None): parser
我在脚本中的 argparse 解析器中添加了一些参数,如下所示: parser = argparse.ArgumentParser() parser.add_argument("--eval_mod
我在 python 代码中使用 argparse 作为参数解析器。将字典解析为 argparse 对象的最佳方法是什么? 例如,我的字典是: { "activation_dropout": 0
我正在使用 argparse从命令行接收输入以运行我的脚本。 我当前的输入字符串如下所示: path> python -t T1 T2 T3 -f F1 F2 argparse 中是否有一个参数,而
我看到了有关使用 argparse 库将字典和列表传递给 Python 的问题。这些示例都显示了我的 Python 代码的样子。但是没有人告诉我它们在命令行上的样子。我在哪里需要大括号、方括号和引号?
我想模拟大多数命令行实用程序的行为,其中可选参数可以放在命令行中的任何位置,包括位置参数之间,例如 mkdir例子: mkdir before --mode 077 after 在这种情况下,我们知道
我想获取传递给 sys.argv 的所有参数有格式someprogram.py --someparameter 23 -p 42 -anotherparam somevalue . 结果我正在寻找一个
这个问题在这里已经有了答案: Argparse optional positional arguments? (3 个回答) 1年前关闭。 我如何才能设置我的 argparser 以具有以下行为? b
这是我的简单 test.py 脚本: import argparse parser = argparse.ArgumentParser('A long string that goes on and
我是一名优秀的程序员,十分优秀!