python subprocess 两次输出流

请问subprocess的输出流不应该是一次么?同时打印两次的时候,第一个可以打印第二次就不能打印了,我理解的有错误么?

python版本:2.6.6

遇到一个这样的问题,rsync同步的时候,我想将同步的信息打印出来。却发现使用(图1)stdout.readline()打印不全,后面使用stout.readlines()将剩下的内容输出了。请问,为什么会出现这个样子?
图片描述图片描述

阅读 3.9k
1 个回答

你不设置 stdout=....PIPE 它就会继承,从而打印到当前 Python 的 stdout 的目标上了。

有剩余的原因是,最后一次 .poll() 返回了结果,while 条件为假,你没有 p.stdout.readline() 了。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题