- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我不确定这个问题是 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
Command failed
--Bye
如果我将 stderr 重定向到一个文件(例如使用 python myscript.py 2> log),该文件包含以下内容:
ls: cannot access '*.foobar': No such file or directory
--Hello
Command failed
--Bye
有没有办法保持文件中消息的顺序(除了在子进程调用中对文件使用 stderr 的显式重定向)?
这个问题类似于一些标准的 stdout/stderr 问题,但在这里,一切都应该在 stderr 上。
最佳答案
您需要将数据写入器刷新到stderr
描述符:
sys.stderr.write("--Hello\n")
sys.stderr.flush()
stdio 在连接到终端时是行缓冲的,而在连接到管道时使用固定缓冲区。您正在编写一个 \n
换行符,它在连接到终端时会触发刷新,但是,如果没有每行刷新,您不会向 stderr
写入足够的内容来触发Python 退出时最终刷新之前的缓冲区刷新。
如果你使用 print(..., file=sys.stderr)
你可以告诉 print()
发出 flush()
通过添加 flush=True
调用:
print("--Hello", file=sys.stderr, flush=True)
处理此问题的另一种方法是“捕获并释放”子进程的 stderr 输出:
sys.stderr.write("--Hello\n")
try:
subprocess.check_call("ls *.foobar", shell=True, stderr=subprocess.PIPE)
except subprocess.CalledProcessError as e:
sys.stderr.write(e.stderr)
sys.stderr.write("Command failed\n")
sys.stderr.write("--Bye\n")
stderr=subprocess.PIPE
添加项告诉 subprocess
捕获命令的 stderr 输出,您可以找到该输出作为 e.stderr
CalledProcessError
异常的属性。
关于python - 子进程 stderr 与 sys.stderr,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52780404/
需要帮助将这些给定的数字打印成星号,但我是编程新手;我该怎么做? #include int main(void) { int a[5]={20,1,5,15,12}; int i=0
使用 Delphi XE 2 我试图确定缩放方向以将缩放效果应用于图像(TImage),但没有找到执行此操作的函数,并且图像的 OnGesture 事件中的 EventInfo 属性没有此信息. 我见
我不知道制服在内存中是如何表示的。 制服似乎会占用宝贵的寄存器空间,但它们最终会传入/通过/传出到全局内存中,对吗? 制服不用时情况会发生变化吗?编译器可以将它们优化掉吗?--在这种情况下,我已经将无
我正在尝试在名为“timeclock”的模型上记录“time_in”和“time_out”记录。这是我想做但无法开始工作的事情! 检查最后一个时钟条目,看看它是否同时填充了“time_in”和“tim
我想听听您如何解决这种编程任务!?每种类型(OPER = 1 类型)对应一种特定的信息。 这只是大约 10 个具有相同结构的规范之一。首选创建这些“转换器”(协议(protocol))的通用方法。 最
我正在使用 Rest API(NodeJS、Express)和 PostgreSQL 制作 React-Native 应用。 在我的本地机器上托管时一切正常。当 API 托管在我的机器上并且 Post
我是一名优秀的程序员,十分优秀!