我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python 通过subprocess运行代码,并实时获得该代码的窗口输出(如print输出、神经网络模型训练和推理相关实时输出等)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python 通过subprocess运行代码,并实时获得该代码的窗口输出(如print输出、神经网络模型训练和推理相关实时输出等)

目录

1. 需求

python主进程唤起一个python子进程,该子进程运行时会实时打印信息,主进程需要获得子进程的实时信息。

这里,需要区分两种情况:当子进程消息较少时,比如自己写的一个子进程,里面用print打印部分信息,此时不需要考虑缓存问题;当子进程消息较多且输出速度快,比如yolov5模型的训练,输出里面存在进度条显示,数据量较大且速度很快,此时需要考虑缓存问题。

主要参考博客《python如何启动新进程,并实时获取程序的输出.》和博客《python subprocess.Popen的使用》

2. 不考虑缓存情况下的实现

此种情况适用于子进程消息较少时,比如自己写的一个子进程,里面用print打印部分信息。

2.1. 子进程测试代码

该代码为子进程测试代码testSub.py,代码内用print进行输出。

import timei = 0while (i<40):    print("当前处于第{}秒".format(i))    time.sleep(1)    i += 1
2.2. 主进程代码

该代码为主进程代码testMain.py,用subprocess.popen运行子进程testSub.py,并获得子进程的实时打印结果。

import subprocessimport threadingclass CMDProcess(threading.Thread):    '''        执行CMD命令行的 进程    '''    def __init__(self, args,callback):        threading.Thread.__init__(self)        self.args = args        self.callback=callback            def run(self):        self.proc = subprocess.Popen(            self.args,            bufsize=0,            shell = False,            stdout=subprocess.PIPE        )                while self.proc.poll() is None:            line = self.proc.stdout.readline()            line = line.decode("utf8")             if(self.callback):                self.callback(line)def getSubInfo(text):    print("子进程测试代码实时输出内容=>" + text)def main():    cmd = [            'python',            '-u', # 注意,这里必须带上-u            'testSub.py'            ]    print("子进程测试代码的运行命令:", ' '.join(cmd))    testProcess = CMDProcess(cmd,getSubInfo )    testProcess.start()main()

3. 考虑缓存情况下的实现

此种情况适用于子进程消息较多且输出速度快,比如yolov5模型的训练,输出里面存在进度条显示,数据量较大且速度很快。

这里,只需要提供主进程代码即可,请注意相关注释内容。该代码为主进程代码testMain.py,用subprocess.popen运行子进程testSub.py,并获得子进程的实时打印结果。

import subprocessimport threadingclass CMDProcess(threading.Thread):    '''        执行CMD命令行的 进程    '''    def __init__(self, args,callback):        threading.Thread.__init__(self)        self.args = args        self.callback=callback        self.cwd = './'             def run(self):        self.proc = subprocess.Popen(            self.args,            bufsize=1, # bufsize=0时,为不缓存;bufsize=1时,按行缓存;bufsize为其他正整数时,为按照近似该正整数的字节数缓存            shell = False,            stdout=subprocess.PIPE,            stderr=subprocess.STDOUT, # 这里可以显示yolov5训练过程中出现的进度条等信息            text=True, # 缓存内容为文本,避免后续编码显示问题            cwd=self.cwd # 这个参数意思是,当前子进程结束后,其结果保存地址,比如yolov5训练进程结束后会输出模型、检测图片等,可在cwd中找到        )                while self.proc.poll() is None:            line = self.proc.stdout.readline()            self.proc.stdout.flush() # 刷新缓存,防止缓存过多造成卡死            #line = line.decode("utf8")             if(self.callback):                self.callback(line)def getSubInfo(text):    print("子进程测试代码实时输出内容=>" + text)def main():    cmd = [            'python',            '-u', # 注意,这里必须带上-u            'testSub.py'            ]      # 这里可以改成yolov5的训练代码,如下    """    cmd = [            'python',            '-u', # 注意,这里必须带上-u            'train.py',            '--img',            '640',            '--batch',            '4',            '--epochs',            '1' #等等,请自行添加参数            ] """    print("子进程测试代码的运行命令:", ' '.join(cmd))    testProcess = CMDProcess(cmd,getSubInfo )    testProcess.start()main()

搭配qt显示,效果如下
在这里插入图片描述

来源地址:https://blog.csdn.net/qq_30841655/article/details/127884956

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python 通过subprocess运行代码,并实时获得该代码的窗口输出(如print输出、神经网络模型训练和推理相关实时输出等)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录