【问题标题】:Python3 argparse nargs="+" get number of argumentsPython3 argparse nargs="+" 获取参数数量
【发布时间】:2021-09-02 08:18:42
【问题描述】:

我现在在谷歌上搜索了很长一段时间,但我没有找到任何解决我问题的方法。

我正在使用 argparse 来解析一些命令行参数。我希望能够解析任意数量的大于 1 的参数(因此 nargs="+"),然后我想知道我已经解析了多少个参数。参数都是字符串。但是当我只有一个参数时我会遇到问题,因为列表的长度是单词的字符数,而不是 1 参数中的 1。我想知道解析了多少参数。有谁知道我该如何解决这个问题?

例子:

from argparse import ArgumentParser

parser = ArgumentParser()
parser.add_argument("--test", type=str, nargs="+", required=False, default="hi")
args = parser.parse_args()
test = args.test

print(test)
print(len(test))

所以python3 example.py --test hello hallo hey 的输出是:

['hello', 'hallo', 'hey']
3

但是python3 example.py --test servus 的输出是:

servus
6

我已经知道我可以这样做 print([test]) 但我只想在有 1 个参数的情况下这样做。因为如果我有多个参数并使用print([test]) 我会得到一个双数组......所以我只想知道“测试”的解析参数的数量。

我无法想象我是唯一一个遇到这种问题的人,但我在互联网上找不到任何东西。有没有快速干净的解决方案?

【问题讨论】:

  • 我希望 args.test['servus'] 长度为 1 的列表。稍后我会验证。通过该测试,您可能希望将默认值更改为列表。
  • 是的,抱歉忘记了(就在这里,不在我的实际代码中)!我明天会尝试你建议的答案并报告:)

标签: python-3.x argparse


【解决方案1】:

您离开了test=args.test 行。

from argparse import ArgumentParser

parser = ArgumentParser()
parser.add_argument("--test", type=str, nargs="+", required=False, default="hi")
args = parser.parse_args()
print(args)
print(len(args.test))

测试用例

0856:~/mypy$ python3 stack68020846.py --test one two three
Namespace(test=['one', 'two', 'three'])
3
0856:~/mypy$ python3 stack68020846.py --test one
Namespace(test=['one'])
1
0856:~/mypy$ python3 stack68020846.py 
Namespace(test='hi')
2

将默认值更改为default=[]

0856:~/mypy$ python3 stack68020846.py 
Namespace(test=[])
0

【讨论】:

  • 完美!现在可以了!我将默认值更改为default=['hi'],现在它工作得非常好!非常感谢!!
【解决方案2】:

可能有更好的解决方案,但试试这个:

from argparse import ArgumentParser

parser = ArgumentParser()
parser.add_argument("--test", type=str, nargs="+", required=False, default="hi")
args = parser.parse_args()

print("Number of arguments:", len(args._get_kwargs()[-1][-1]))

顺便说一句,我通过print(dir(args))检查 args 的内容发现了这一点

【讨论】:

  • 他可能遗漏了test=args.test 行。
猜你喜欢
  • 2015-07-25
  • 2016-07-19
  • 2016-11-01
  • 1970-01-01
  • 1970-01-01
  • 2017-02-23
  • 2014-10-11
  • 2017-08-20
  • 2023-04-09
相关资源
最近更新 更多