• python--终端工具之subprocess


    一、

    subprocess.getstatusoutput
    import subprocess
    cmd = 'ifconfig'
    def cmds(cmd,print_msg=True):
        status,result = subprocess.getstatusoutput(cmd)
        if status > 0:
            return {"status":"failed","msg":result}
        return {"status":"succeed","msg":result}

      可以将执行之后的状态和执行结果反馈,但是痛点:result是一次性返回,简单的说就是,比如你执行一条ping www.baidu.com的命令,程序一直是在执行状态,无任何输出,只当执行结束后返回status和result

    二、

    subprocess.Popen
    import subprocess
    cmd = 'ping www.baidu.com'
    def cmds(cmd,print_msg=True):
        p = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
        print(p.stderr)
        lines = []
        for line in iter(p.stdout.readline, b''):
            line = line.rstrip().decode('utf8')
            if print_msg:
                print(">>>", line)
    if __name__ == '__main__':
        
        cmds(cmd)

      成功解决之前的问题,可将命令的执行结果实时更新,但是在执行结束之后并不能得知其执行状态是成功或失败

    def cmds(self,cmds, print_msg=True):
            compilePopen = subprocess.Popen(cmds,shell=True,stdout=subprocess.PIPE,close_fds=True,stderr=subprocess.STDOUT)
            compilePopen.wait()    # 没有这个无法得知compilePopen.returncode状态是否成功
            for line in iter(compilePopen.stdout.readline, b''):
                msg = line.rstrip().decode('utf8')if print_msg:
                    self.ws.send(json.dumps({
                        "progress": "run_script",
                        "msg": msg,
                        'ctime': time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()),
                        'user': self.task.username
                    }))
            # if compilePopen.returncode >= 0:  # 执行成功
         
    # else: # 执行失败

    重新调整了之后可以将实时内容和执行状态都做拿到,但是亲测感觉效率并不好,还有没有更好的办法呢?



    或者
    def sh(self,cmds, print_msg=True):
        print('sh')
        msgStr = []
        env = Business_Env_Assets.objects.filter(id=self.apps.env).first().name
        compilePopen = subprocess.Popen(cmds,shell=True,stdout=subprocess.PIPE,close_fds=True,stderr=subprocess.STDOUT)
        returnMsg = ''
        for line in iter(compilePopen.stdout.readline, b''):
            line = line.rstrip().decode('utf8')
    print(line)
    stdout, stderr = compilePopen.communicate() returncode = compilePopen.returncode if returncode > 0: result = {"status": "failed", "msg": returnMsg} result = {"status": "succeed", "msg": returnMsg} self.handle_result("post_deploy", result)


  • 相关阅读:
    2021.1.18 HTML标签及元素
    嵌入式发展史简述及一些概念
    06 突破512字节的限制 上
    50 排序的工程应用示例
    01 进阶操作系统
    05 主引导程序的扩展-下
    04 主引导程序的扩展-上
    03 调试环境的搭建
    在windows下使用linux命令,GnuWin32的使用.
    gcc -I -L -l区别
  • 原文地址:https://www.cnblogs.com/lutt/p/12207809.html
Copyright © 2020-2023  润新知