上面的例子中,我们执行了一个sleep 10的shell操作。将执行的状态保存在status变量中,将执行结果保存在result变量中。
结果中可以看到status返回0,而result返回空值。我们脚本执行的开始时间start_time
和脚本的最后输出时间end_time
中间,有10s的时间差。
如果我们有一个shell命令,需要执行很久,例如1个小时,这个时候,如果我们用commands.getstatusoutput
模块的话,只能等这个python脚本执行完,才能得到shell脚本最终的执行结果。
因为执行的时间很长,所以有时候我们想要查询执行的中间状态来确保当前程序依旧在执行中,而不是挂掉了。commands.getstatusoutput
是不能查看命令执行的中间状态的。
02.如何查看shell命令中间状态?
这里我们需要引入另外一个模块,subpress模块,这个模块中有一个类Popen,可以查看当前命令执行过程中间的状态,如下:
‘’’
遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
‘’’
import subprocess
import datetime
import time
proc = subprocess.Popen(“sleep 10”,shell=True, stdout=subprocess.PIPE)
print “proc is {}”.format(proc)
time.sleep(5)
print ‘5s result is : {}’.format(proc.poll())
time.sleep(10)
print ‘10s tmp result is : {}’.format(proc.poll())
----执行结果-----
proc is <subprocess.Popen object at 0x7faff43f0e10>
5s result is : None
10s tmp result is : 0
可以看到,我们引用subpress模块的Popen类来执行sleep 10这个shell命令。这个Popen类还包含一个poll的函数,来查看当前命令的返回值。如上述结果:
-
5s的时候,输出的结果是None,代表sleep 10还在执行中;
-
10s的时候,输出的结果是0,代表sleep 10执行成功。
这样就可以捕捉命令的执行中间过程,我们完全可以写一个while 1的循环,等待某个命令的返回值为0,在开始执行后面的命令。还可以将执行的中间结果打印到屏幕上,避免执行命令的时候,完全是一个黑盒状态。
这个Popen类中还有其他很有用的函数,这里简要介绍,有需求可以去研究下:
| Popen.poll() | 用于检查子进程(命令)是否已经执行结束,没结束返回None,结束后返回状态码。 |
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)
识点,真正体系化!**
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)