Python 没有检测到子字符串,即使它存在(该字符串来自 argparse 的输出)

Python is not detecting a substring, even though it is there (the string is from the output of argparse)

我有一个字符串(当你输入 python parser.py foo 并使用 argparse 时的输出)是:

(旁注:我检查过它是否是一个字符串,确实是。)

因此,我试图查看 foo 一词是否在此字符串中。所以,我正在使用

print("foo" in argparse_string_output)

显然,这应该输出 True。但这输出False,我不知道为什么。请帮忙!


代码: parser.py

import argparse

def create_parser():
  parser = argparse.ArgumentParser()
  subparsers = parser.add_subparsers(help='sub-command -h', dest='command')

  add_parser = subparsers.add_parser("add", help="add -h")

  return parser

if __name__ == "__main__":
  create_parser().parse_args()

包含 in 语句的文件(名为 readout.py)

import os


def runargs(cmd):
  newcmd = ["python", "parser.py"] + cmd
  return os.popen(" ".join(newcmd)).read()

if __name__ == "__main__":
  x = runargs(["foo"])
  print(x)
  print(x, "foo" in x)

我的完整代码在 GitHub(我在这里进行了简化,因为我告诉你我输入的路径是错误的)。它在这里:Github link。此外,获得此输出的真正命令是 python tests/readout.py

你的问题是你希望获取的输出是 stderr 而不是 stdout,而你获取的是 stdout。这是我 运行 您的代码时得到的结果:

01:58:51 (dev3) steve@US-ST032JO-MLT blah ±|master ✗|→ python foo.py
usage: parser.py [-h] {add} ...
parser.py: error: argument command: invalid choice: 'foo' (choose from 'add')

 False

另一方面,如果我修改您的代码以像这样将 stderr 重定向到 stdout:

def runargs(cmd):
  newcmd = ["python", "parser.py"] + cmd + ['2>&1']
  return os.popen(" ".join(newcmd)).read()

if __name__ == "__main__":
  x = runargs(["foo"])
  print(x)
  print(x, "foo" in x)

然后我得到了我认为你期望的行为:

01:59:11 (dev3) steve@US-ST032JO-MLT blah ±|master ✗|→ python foo.py
usage: parser.py [-h] {add} ...
parser.py: error: argument command: invalid choice: 'foo' (choose from 'add')

usage: parser.py [-h] {add} ...
parser.py: error: argument command: invalid choice: 'foo' (choose from 'add')
 True

看到输出由 Python 本身写入控制台并认为它来自您的 print() 语句,您是否感到困惑?正如您在此处看到的,如果代码按预期工作,您的 print() 语句将打印输出的第二个副本。