Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
本文介绍了实时读取子进程中的标准输出的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
给定此代码片段:
from subprocess import Popen, PIPE, CalledProcessError
def execute(cmd):
with Popen(cmd, shell=True, stdout=PIPE, bufsize=1, universal_newlines=True) as p:
for line in p.stdout:
print(line, end='')
if p.returncode != 0:
raise CalledProcessError(p.returncode, p.args)
base_cmd = [
"cmd", "/c", "d:\virtual_envs\py362_32\Scripts\activate",
"&&"
]
cmd1 = " ".join(base_cmd + ['python -c "import sys; print(sys.version)"'])
cmd2 = " ".join(base_cmd + ["python -m http.server"])
如果我运行execute(cmd1)
,则会毫无问题地打印输出。
但是,如果我运行execute(cmd2)
,则不会打印任何内容,这是为什么?我如何修复它以便可以实时查看HTTP.SERVER的输出。
for line in p.stdout
是如何在内部评估的?它是不是某种无休止的循环,直到到达标准的Eof或其他什么?
这个话题在本文中已经讨论过几次了,但我还没有找到Windows解决方案。上述代码片段来自answer,我正在从Virtualenv(在Win7上为python3.6.2-32bit)运行HTTP.SERVER
推荐答案
如果要从正在运行的子进程中连续读取,则必须使该进程的输出无缓冲。您的子进程是一个Python程序,这可以通过将-u
传递给解释器来完成:
python -u -m http.server
这是它在Windows框上的外观。
这篇关于实时读取子进程中的标准输出的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:实时读取子进程中的标准输出


基础教程推荐
猜你喜欢
- 使用PyInstaller后在Windows中打开可执行文件时出错 2022-01-01
- Python kivy 入口点 inflateRest2 无法定位 libpng16-16.dll 2022-01-01
- 如何在海运重新绘制中自定义标题和y标签 2022-01-01
- 在 Python 中,如果我在一个“with"中返回.块,文件还会关闭吗? 2022-01-01
- 如何让 python 脚本监听来自另一个脚本的输入 2022-01-01
- 何时使用 os.name、sys.platform 或 platform.system? 2022-01-01
- Dask.array.套用_沿_轴:由于额外的元素([1]),使用dask.array的每一行作为另一个函数的输入失败 2022-01-01
- 筛选NumPy数组 2022-01-01
- 线程时出现 msgbox 错误,GUI 块 2022-01-01
- 用于分类数据的跳跃记号标签 2022-01-01