- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设我有一个输入文件选项和一个输出文件选项。如何创建将两者结合起来的选项?例如:
$ ./my_script.py -i input.txt -o output.txt
$ ./my_script.py --io input_output.txt
-io
来组合这两个选项,但
-io filename
是
-i -o filename
的快捷方式,而不是
-i filename -o filename
。
dest=('input', 'output')
添加到我的
.add_argument()
调用中,但这引发了
dest
必须是字符串的错误。
--io
的互斥组,在另一侧添加一组
-i
和
-o
,但是当使用
-i
运行程序时,
-o
和
--help
的帮助文本不再显示:
usage: myscript.py [-h] [--io] [-i INPUT] [-o OUTPUT]
optional arguments:
-h, --help show this help message and exit
--io Use file as both input and output
--io
以及单独的
-i
和
-o
选项调用脚本,并且不会引发错误。
import argparse
parser = argparse.ArgumentParser()
parser.add_argument("-i", "--input", help="Input file")
parser.add_argument("-o", "--output", help="Output file")
parser.parse_args()
import argparse
parser = argparse.ArgumentParser()
exclusive = parser.add_mutually_exclusive_group()
exclusive.add_argument("--io", help="Input and Output")
sub = exclusive.add_argument_group()
sub.add_argument("-i", "--input", help="Input file")
sub.add_argument("-o", "--output", help="Output file")
args = parser.parse_args()
if args.io:
in_file = out_file = args.io
else:
in_file = args.input
out_file = args.output
最佳答案
解释为什么事情不起作用比提出解决方案更容易。
是的,dest
必须是字符串;没有提供 dest
值的列表或元组。但是您的 in_file = out_file = args.io
很好地解决了这个问题。你也可以使用:
args.in_file=args.out_file = args.io
args
值没有任何问题。
argument_group
不是为嵌套而设计的,也不是向
mutually_exclusive_group
添加“任何”(或“和”)逻辑的方式。也许在遥远的将来会有一种定义完整逻辑组合的方法,但现在不行。其实做测试并不难;很难定义 API 和使用格式。
mutually_exclusive_group
用于格式化参数的使用和测试 co_ocurrance,而
argument_group
用于对参数帮助行进行分组。两个截然不同的目的。
-i
是
store_true
参数,那么
-io filename
将被理解为
-i -o filename
。但是翻译它太
-i filename -o filename
不在当前代码中(并且可能不够常见以保证补丁)。
-i
、
-o
和
--io
(我更喜欢
--
用于 2 个字符标志),我可以建议以下几点:
exclusive groups
测试。 args.in_file is None
是测试是否使用标志的好方法。另一种可能性是定义默认值,这样您就不必关心用户使用哪种组合。 关于python - 用于组合其他选项的 Argparse 快捷选项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38024501/
我正在尝试使用 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
我是一名优秀的程序员,十分优秀!