python 运行 在 bash 和子进程上时的不同输出
python different output when run on bash and subprocess
我正在 运行ning 一个内部调用 bash 命令并相应地解析输出的脚本。
例如我调用这个命令
result = subprocess.check_output("rg result",shell=True)
print(output)
我得到的输出没有任何行号或任何东西
historyChecker.py: result = subprocess.check_output("rg --help",shell=True)
historyChecker.py: output = re.search(r'USAGE:',result)
如果我 运行 在 bash 中执行相同的命令,我会得到不同的结果
[~/history_checker/code]$ rg result
historyChecker.py
56: result = subprocess.check_output("rg --help",shell=True)
57: output = re.search(r'USAGE:',result)
知道为什么会发生这种情况以及我们如何解决这个问题。
谢谢
来自 rg
的文档:
-n
, --line-number
Show line numbers (1-based). This is enabled by default when searching in a terminal.
所以当你在终端中 运行 它时,这个选项被启用。当您使用 subprocess.check_output()
时,标准输出连接到管道,并且未启用此选项。
如果需要,请添加 --line-number
选项。
result = subprocess.check_output(["rg", "--line-number", "result"])
print(output)
您也没有做任何需要 shell 解析的事情,因此将命令行作为列表传递并且不要使用 shell=True
.
我正在 运行ning 一个内部调用 bash 命令并相应地解析输出的脚本。 例如我调用这个命令
result = subprocess.check_output("rg result",shell=True)
print(output)
我得到的输出没有任何行号或任何东西
historyChecker.py: result = subprocess.check_output("rg --help",shell=True)
historyChecker.py: output = re.search(r'USAGE:',result)
如果我 运行 在 bash 中执行相同的命令,我会得到不同的结果
[~/history_checker/code]$ rg result
historyChecker.py
56: result = subprocess.check_output("rg --help",shell=True)
57: output = re.search(r'USAGE:',result)
知道为什么会发生这种情况以及我们如何解决这个问题。 谢谢
来自 rg
的文档:
-n
,--line-number
Show line numbers (1-based). This is enabled by default when searching in a terminal.
所以当你在终端中 运行 它时,这个选项被启用。当您使用 subprocess.check_output()
时,标准输出连接到管道,并且未启用此选项。
如果需要,请添加 --line-number
选项。
result = subprocess.check_output(["rg", "--line-number", "result"])
print(output)
您也没有做任何需要 shell 解析的事情,因此将命令行作为列表传递并且不要使用 shell=True
.