PyTest PyQt pytest控制台输出日志重定向到Qt程序界面文本框PlainTextEdit

3 篇文章 0 订阅

代码:

class Signal(QObject):
    text_update = pyqtSignal(str)
    def write(self, text):
        self.text_update.emit(str(text))
        QApplication.processEvents()

    def isatty(self):
        return True

    def flush(self):
        pass


class MyMainWindow(QMainWindow, Ui_MainWindow, QObject):

    def __init__(self, parent=None):
        super(MyMainWindow, self).__init__(parent)  # 初始化父类属性
        self.setupUi(self)
        sys.stdout = Signal()
        sys.stdout.text_update.connect(self.updatetext)

    def updatetext(self, text):
        if text == '\n' or str(text).strip() == '': return
        self.plainTextEdit_log.appendPlainText(
                time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) + ": " + text)
        cursor = self.plainTextEdit_log.textCursor()
        cursor.movePosition(QTextCursor.End)

关于Signal类:

pytest内部会调用file类的isatty()和flush()两个函数,这里Signal可以认为就是file,定义同名函数实现就可以了。因为不是写入文件,所以flush函数没啥用,pass掉就行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值