python使用subprocess.Popen 进程一直被堵塞的解决方案

代码: 

import tempfile, inspect


# 创建临时文件, 用于存储 subprocess.Popen的输出
out_temp = tempfile.SpooledTemporaryFile(max_size=10*1000)
fileno = out_temp.fileno()

process = subprocess.Popen(command, stdout=fileno, stderr=fileno, shell=True)
process.wait()

# 获取命令输出
out_temp.seek(0)
output = out_temp.read()
error = out_temp.read()
print(inspect.currentframe().f_code.co_name, inspect.currentframe().f_lineno, "output: ", output.decode("utf-8"))
print(inspect.currentframe().f_code.co_name, inspect.currentframe().f_lineno, "error: ",  error.decode("utf-8"), "\n\n")

要在 Python使用 `subprocess.Popen` 方法开启非阻塞模式,你可以使用 `subprocess.PIPE` 参数来重定向子进程的标准输出和标准错误输出,并使用 `communicate` 方法来获取子进程的输出结果。 以下是一个示例: ```python import subprocess # 启动子进程并立即继续执行接下来的程序 process = subprocess.Popen(['command', 'arg1', 'arg2'], stdout=subprocess.PIPE, stderr=subprocess.PIPE) # 非阻塞模式下读取子进程的输出结果 output, error = process.communicate() # 处理子进程的输出结果 ``` 在上述示例中,我们将 `stdout` 和 `stderr` 参数都设置为 `subprocess.PIPE`,这样子进程的输出将会被重定向到管道中。然后,我们可以使用 `communicate` 方法来读取子进程的输出结果。注意,`communicate` 方法会等待子进程执行完毕并返回输出结果。 另外,如果你希望在启动子进程后立即继续执行接下来的程序而不等待子进程执行完毕,可以使用 `process.poll()` 方法来检查子进程是否已经执行完毕。如果返回值为 `None`,表示子进程还在运行;如果返回值不为 `None`,则表示子进程已经执行完毕。 以下是一个使用阻塞模式的示例: ```python import subprocess # 启动子进程并立即继续执行接下来的程序 process = subprocess.Popen(['command', 'arg1', 'arg2'], stdout=subprocess.PIPE, stderr=subprocess.PIPE) # 检查子进程是否已经执行完毕 while process.poll() is None: # 这里可以继续执行其他操作 pass # 子进程已经执行完毕,可以处理子进程的输出结果 output, error = process.communicate() ``` 这样,你可以在子进程执行的同时,继续执行其他操作。当子进程执行完毕后,再使用 `communicate` 方法来获取输出结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值