我不确定这个问题是 Python 还是 shell 问题。
我有一个 Python 程序,它在命令上使用子进程调用,该命令可以在 stderr 上发出错误消息。我自己的程序也使用 sys.stderr 来记录错误。这是一个简单的示例,命令 (ls *.foobar) 失败:
import sys,subprocess
sys.stderr.write("--Hello\n")
try:
subprocess.check_call("ls *.foobar",shell=True)
except subprocess.CalledProcessError as e:
sys.stderr.write("Command failed\n")
sys.stderr.write("--Bye\n")
当我运行此代码时,控制台上的输出(来自 stderr)如下:
--Hello
ls: cannot access '*.foobar': No such file or directory
命令失败
--Bye
如果我将 stderr 重定向到一个文件(例如使用 python myscript.py 2> log),该文件包含以下内容:
ls: cannot access '*.foobar': No such file or directory
--Hello
命令失败
--Bye
有没有办法保持文件中消息的顺序(除了在子进程调用中对文件使用 stderr 的显式重定向)?
这个问题类似于一些标准的 stdout/stderr 问题,但在这里,一切都应该在 stderr 上。