zoukankan      html  css  js  c++  java
  • python3 subprocess模块

    当我们在执行python程序的时候想要执行系统shell可以使用subprocess,这时可以新起一个进程来执行系统的shell命令,python3常用的有subprocess.run()和subprocess.Popen,两者的区别是前者是调用的后者,相当于是subprocess.run是subprocess.Popen的又一层封装,前者必须要等待子进程运行结束才会返回,python主进程会被阻塞,而后者已运行则立即返回对象,不用等待子进程运行结束,也可以使用wait()方法等待子进程运行结束,后期可以使用返回的对象调用子进程运行的结果。

    ###base.py:

    import time
    time.sleep(2)
    print('hello')

    ##main.py

    import subprocess
    p=subprocess.run(['python','base.py'],stdout=subprocess.PIPE)
    data=p.stdout
    print(str(data,encoding='gbk'))
    print('end')

    ################################################################
    res_obj=[]
    for i in range(3):
    p=subprocess.Popen(['python','base.py'],stdout=subprocess.PIPE)
    # data=p.communicate() #如果启用此相会阻塞主程序
    # p.wait() #等待子程序运行完毕
    # print(data)

    res_obj.append(p) #将返回的对象加入到列表,后期通过此对象调用子程序执行结果
    print('程序后台运行中')

    for i in res_obj:
    print(i.communicate()) #获取子程序执行结果
  • 相关阅读:
    Go
    list的基本操作实现
    天梯赛练习题L2-006. 树的遍历
    部署 Fluent Bit ( td-agent-bit )
    elastalert + supervisor
    elastalert搭建
    Docker 部署 kibana( ES开启了密码认证)
    Docker 部署 elasticsearch( ES开启了密码认证)
    Python yaml模块
    Python json和pickle模块
  • 原文地址:https://www.cnblogs.com/dufeixiang/p/10266236.html
Copyright © 2011-2022 走看看