- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一本字典,它将人类可读的值映射到三个不同的 Python 特定值。 argparse Python 模块如何使用这个字典来获取特定值,同时用户可以在键之间进行选择。
目前我有这个:
def parse(a):
values = { "on": True, "off": False, "switch": None }
parser = argparse.ArgumentParser()
parser.add_argument("-v", "--value", choices=values, default=None)
args = parser.parse_args(a)
print("{}: {}".format(type(args.value), args.value))
>>> parse(['-v', 'on'])
<type 'str'>: on
>>> parse(['-v', 'off'])
<type 'str'>: off
>>> parse(['-v', 'switch'])
<type 'str'>: switch
>>> parse([])
<type 'NoneType'>: None
问题是,如果给定参数,argparse 不会返回 True
、False
或 None
。有没有简单的方法来添加此功能?当然我之后可以执行这样的事情:
args.value = values[args.value]
这实际上是我目前正在做的事情,但这不适用于默认值(我必须检查该值是否已经为 None 或将默认值设置为 "switch"
).由于我多次使用它,所以我每次都必须这样做。
最佳答案
最小的改变是使用
args.value = values.get(args.values)
因此对于不在字典中的任何条目(例如默认值),您将得到 None。
另一种选择是滥用 argparse 的 type 关键字:
values = { "on": True, "off": False, "switch": None }
def convertvalues(value):
return values.get(value)
parser.add_argument('-v','--value',type=convertvalues)
“类型”方法打破了上面使用的选择的使用,因为选择是在转换之后应用的。保留您对选择的使用的一种可能性是:
def convertvalues(value):
return values.get(value,value)
parser.add_argument('-v','--value',type=convertvalues,
choices=[True,False,None],
default=None)
在这种情况下,如果使用 'on'、'off'、'switch' 和 None,则 convertvalues 返回正确的值,如果给出其他内容(例如,'bla'),则返回给定的值。由于“bla”不在选项中,您会收到预期的错误消息。
将“action”与从 argparse.Action 派生的类一起使用而不是类型应该以聪明的方式完成这项工作,如 docs 中给出的那样:
class DictAction(argparse.Action):
def __call__(self, parser, namespace, values, option_string=None):
value_dict = { "on": True, "off": False, "switch": None }
setattr(namespace, self.dest, value_dict.get(values))
parser.add_argument('-v','--value',action=DictAction,
choices=['on','off','switch'],
default=None)
当然这并不完美,更好的解决方案是覆盖 Acion init 以获取字典并省略硬编码的 value_dict。
关于python - 为 Python argparse 使用字典,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22635675/
我正在尝试使用 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
我是一名优秀的程序员,十分优秀!