import subprocesswhile True: proc = subprocess.Popen(["python3", "/home/pi/Documents/8-17/simplest.py"]) proc.wait() # 等待子进程执行完毕 if proc.returncode == 0: print("simplest运行正常.....") break simplest执行后终端一直打印simplest的输出而不会打印if判断里的输出,子进程simplest是一个不会运行结束的程序
时间: 2023-12-10 22:39:11 浏览: 19
这是因为 `proc.wait()` 会阻塞主进程,直到子进程执行完毕。而你的子进程 simpletst 是一个不会运行结束的程序,所以主进程就一直被阻塞了。
你可以使用 `proc.poll()` 来检查子进程是否已经结束,如果已经结束,则 `poll()` 方法会返回子进程的退出码或 None。这样,你就可以在等待子进程结束的同时,定期检查子进程是否已经结束,从而避免主进程一直被阻塞。
下面是修改后的代码:
```
import subprocess
import time
while True:
proc = subprocess.Popen(["python3", "/home/pi/Documents/8-17/simplest.py"])
while proc.poll() is None:
time.sleep(1) # 每秒钟检查一次子进程是否结束
if proc.returncode == 0:
print("simplest运行正常.....")
break
```
相关问题
import subprocesswhile True: proc = subprocess.Popen(["python3", "/home/pi/Documents/8-17/simplest.py"]) proc.wait() # 等待子进程执行完毕 if proc.returncode == 0: print("simplest运行正常.....") break simplest执行后终端一直打印simplest的输出而不会打印if判断里的输出,simplest是一个不会运行结束的程序
这是因为 `Popen` 函数启动的子进程在执行 `simplest.py` 时一直在输出信息,导致主进程一直等待子进程结束,无法执行后续代码。您可以使用 `communicate` 方法,在子进程执行结束后获取其输出,或者将子进程的输出重定向到文件中,避免输出影响主进程。例如:
```python
import subprocess
while True:
proc = subprocess.Popen(["python3", "/home/pi/Documents/8-17/simplest.py"], stdout=subprocess.PIPE)
out, err = proc.communicate() # 获取子进程的输出
if proc.returncode == 0:
print("simplest运行正常.....")
break
```
或者:
```python
import subprocess
while True:
with open('simplest_output.txt', 'w') as f:
proc = subprocess.Popen(["python3", "/home/pi/Documents/8-17/simplest.py"], stdout=f)
proc.wait() # 等待子进程执行完毕
if proc.returncode == 0:
print("simplest运行正常.....")
break
```
import subprocess while True: proc = subprocess.Popen(["python3", "/home/pi/Documents/8-17/simplest.py"]) try: while True: if proc.poll() is not None: break print("simplest运行成功.....") except KeyboardInterrupt: proc.terminate() break 这样simplest死循环里打印的信息不会出现在终端
这是因为 `subprocess.Popen` 创建的子进程是在独立的进程空间内执行的,并不会把输出打印到终端。要想在终端打印子进程的输出,可以使用 `subprocess.PIPE` 来捕获子进程的标准输出和标准错误输出,然后在父进程中打印出来。修改代码如下:
```python
import subprocess
while True:
proc = subprocess.Popen(["python3", "/home/pi/Documents/8-17/simplest.py"],
stdout=subprocess.PIPE, stderr=subprocess.PIPE)
try:
while True:
if proc.poll() is not None:
break
# 读取子进程的输出
output = proc.stdout.readline().decode().strip()
if output:
print(output)
error = proc.stderr.readline().decode().strip()
if error:
print(error)
except KeyboardInterrupt:
proc.terminate()
break
```
这样就可以实时打印子进程的输出了。