PyQt(Python+Qt)学习随笔:print标准输出sys.stdout以及stderr重定向QTextBrowser等图形界面对象

在Python实现print标准输出sys.stdout、stderr重定向及捕获的简单办法》介绍了Python实现重定向的方法,在PyQt程序中,可以在上文的基础上,将标准输出信息输出重定向到类似QTextBrowser、QLineEdit、QLabel等图形界面对象上。

实现步骤如下:

  1. 备份标准输出sys.stdout、stderr对象,以便恢复或做其他处理;
  2. 在主界面派生类或其他图像界面派生类中定义write方法
    Python判断对象是否支持文件IO,是个典型的鸭子类型处理方式,就是看对象是否实现了读写方法,由于标准输出无需读只需写,因此只要在图形界面派生类实现了write方法后即可使用该图形界面类的实例替代标准输出即可
  3. 在图形界面派生类write方法中将要输出信息输出到图形界面类子对象中
    在此需要注意,输出到图形对象的信息在程序输出过程中可能不会即时显示,导致给人的感觉是没有输出一样,为了确保输出信息即时显示需要在write方法中主动调用应用的processEvents方法。

示例代码:

class mainWin(QtWidgets.QWidget,ui_mainWin.Ui_mainWin):
    def __init__(self):
        super().__init__()
        self.setupUi(self)
        self.stdoutbak = sys.stdout
        self.stderrbak = sys.stderr
        sys.stdout = self

	def write(self,info):
        self.proccessInf.insertPlainText(info)
        if len(str):self.currentInf.setText(str)
        QtWidgets.qApp.processEvents(QtCore.QEventLoop.ExcludeUserInputEvents|QtCore.QEventLoop.ExcludeSocketNotifiers)
        self.stdoutbak.write(info)

	def restoreStd(self):
        print("准备恢复标准输出")
        sys.stdout = self.stdoutbak 
        sys.stderr = self.stderrbak 
        print("恢复标准输出完成")
        
	def __del__(self):
       self.restoreStd()

以上方法不但能捕获自己实现代码的输出到图形界面中,还能将第三方模块输出信息也捕获到图形界面中。具体可以参考《第15.40节、PyQt(Python+Qt)实战:moviepy实现MP4视频转gif动图的工具

老猿Python,跟老猿学Python!

posted @ 2020-04-04 21:46  老猿学Python  阅读(520)  评论(0编辑  收藏  举报