pyQt5 时时输出显示(PyCharm QtDesigner PyUIC开发)

pyQt5 时时输出显示(PyCharm QtDesigner PyUIC开发)用QtDesigner工具进行界面绘制,注意各种插件的命名,以免生成的代码自己都看不懂。绘制好之后,再利用PyUIC把.ui文件转为.py文件。PyCharm可以集成QtDesignerPyUIC这两种工具。func.py:#-*-coding:utf-8-*-#Formimplementationgeneratedfromreadinguifile…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

用QtDesigner工具进行界面绘制,注意各种插件的命名,以免生成的代码自己都看不懂。

绘制好之后,再利用PyUIC把.ui文件转为.py文件。

PyCharm可以集成QtDesigner PyUIC这两种工具。

func.py:

# -*- coding: utf-8 -*-

# Form implementation generated from reading ui file 'func.ui'
#
# Created by: PyQt5 UI code generator 5.5.1
#
# WARNING! All changes made in this file will be lost!
from subprocess import Popen
from threading import Thread
import time
from PyQt5 import QtCore, QtGui, QtWidgets
import subprocess
import threading
from PyQt5.QtCore import *


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(1014, 695)
        # self.ads = QtWidgets.QWidget(MainWindow)
        # self.ads.setObjectName("ads")
        self.horizontalLayoutWidget = QtWidgets.QWidget()
        self.horizontalLayoutWidget.setGeometry(QtCore.QRect(50, 80, 871, 521))
        self.horizontalLayoutWidget.setObjectName("horizontalLayoutWidget")
        self.horizontalLayout = QtWidgets.QHBoxLayout(self.horizontalLayoutWidget)
        self.horizontalLayout.setObjectName("horizontalLayout")
        self.verticalLayout_5 = QtWidgets.QVBoxLayout()
        self.verticalLayout_5.setObjectName("verticalLayout_5")
        self.driverWin_label = QtWidgets.QLabel(self.horizontalLayoutWidget)
        self.driverWin_label.setObjectName("driverWin_label")
        self.verticalLayout_5.addWidget(self.driverWin_label, 0, QtCore.Qt.AlignHCenter)
        self.driver_win = QtWidgets.QTextBrowser(self.horizontalLayoutWidget)
        self.driver_win.setObjectName("textBrowser")
        self.verticalLayout_5.addWidget(self.driver_win)
        self.horizontalLayout.addLayout(self.verticalLayout_5)
        self.verticalLayout_3 = QtWidgets.QVBoxLayout()
        self.verticalLayout_3.setObjectName("verticalLayout_3")
        self.label = QtWidgets.QLabel(self.horizontalLayoutWidget)
        self.label.setText("")
        self.label.setObjectName("label")
        self.verticalLayout_3.addWidget(self.label)
        self.start_button = QtWidgets.QPushButton(self.horizontalLayoutWidget)
        self.start_button.setObjectName("start_button")
        self.verticalLayout_3.addWidget(self.start_button)
        self.stop_button = QtWidgets.QPushButton(self.horizontalLayoutWidget)
        self.stop_button.setObjectName("stop_button")
        self.verticalLayout_3.addWidget(self.stop_button)
        spacerItem = QtWidgets.QSpacerItem(20, 40, QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Expanding)
        self.verticalLayout_3.addItem(spacerItem)
        self.horizontalLayout.addLayout(self.verticalLayout_3)
        self.verticalLayout_4 = QtWidgets.QVBoxLayout()
        self.verticalLayout_4.setObjectName("verticalLayout_4")
        self.armWin_label = QtWidgets.QLabel(self.horizontalLayoutWidget)
        self.armWin_label.setObjectName("armWin_label")
        self.verticalLayout_4.addWidget(self.armWin_label, 0, QtCore.Qt.AlignHCenter)
        self.armWin = QtWidgets.QTextBrowser(self.horizontalLayoutWidget)
        self.armWin.setObjectName("armWin")
        self.verticalLayout_4.addWidget(self.armWin)
        self.transmitWin_label = QtWidgets.QLabel(self.horizontalLayoutWidget)
        self.transmitWin_label.setObjectName("transmitWin_label")
        self.verticalLayout_4.addWidget(self.transmitWin_label, 0, QtCore.Qt.AlignHCenter)
        self.transmitWin = QtWidgets.QTextBrowser(self.horizontalLayoutWidget)
        self.transmitWin.setObjectName("transmitWin")
        self.verticalLayout_4.addWidget(self.transmitWin)
        self.horizontalLayout.addLayout(self.verticalLayout_4)
        MainWindow.setCentralWidget(self.horizontalLayoutWidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 1014, 26))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)

        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
        #self.driver_win.append("%s" % '111')

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        self.driverWin_label.setText(_translate("MainWindow", "driver window"))
        self.start_button.setText(_translate("MainWindow", "start"))
        self.stop_button.setText(_translate("MainWindow", "stop"))
        self.armWin_label.setText(_translate("MainWindow", "arm window"))
        self.transmitWin_label.setText(_translate("MainWindow", "transmit window"))


class show_thred(QThread):
    sinOut = pyqtSignal(str)

    def __init__(self,show_win,data):
        self.data = data
        self.show_win = show_win
        super().__init__()

    def run(self):
        while self.data.poll is not None:
            #self.show_win.append(str(self.data.stdout.readline()))
            outputdata = self.data.stdout.readline()
            self.sinOut.emit(str(outputdata))


class func_ui(Ui_MainWindow):
    driver_thread = ...  # type: Thread
    data = ...  # type: Popen
    driver_show = ...

    def __init__(self, MainWindow):
        self.setupUi(MainWindow)
        self.data = subprocess.Popen('./a.out', stdout=subprocess.PIPE, stdin=subprocess.PIPE,shell=True)
        self.start_button.clicked.connect(self.start_button_click)

    @pyqtSlot()
    def start_button_click(self):
        self.driver_show = show_thred(self.driver_win,self.data)
        self.driver_show.sinOut.connect(self.show_driver_text)
        self.driver_show.start()

    def show_driver_text(self,msg):
        print(msg)
        self.driver_win.append(msg)

Ui_MainWindow和retranslateUi都是用PyUIC生成的,需要注意的是,自动生成的添加了一个窗口部件,我把它注释替换了。

原本的设计是想像tk库一样,在单独的线程中填充文本框,但是QT中,我没有实现这样的功能,在主线程创建的text部件,在另外的线程去填充内容会报警告,出现段错误。QT的C++版本提供了函数来解决这个问题,但是Python中我没有找到。所以采用了另外的方式。线程读取内容,然后再传递给主线程(UI线程),再在UI线程中添加内容到text中。

 

main.py:

#!/usr/bin/python3.5
import func
import sys
#引入模块,基本控件位于pyqt5.qtwidgets
from PyQt5.QtWidgets import QApplication,QWidget
from PyQt5 import QtCore, QtGui, QtWidgets

if __name__ == "__main__":

    app = QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = func.func_ui(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

pyQt5 时时输出显示(PyCharm QtDesigner PyUIC开发)

效果图如上,布置界面的时候加入了各种布局(横纵),所以所有的部件都可以跟随窗口的大小改变大小

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/175136.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • reaver使用相关[通俗易懂]

    reaver使用相关[通俗易懂](非TP-LINK路由推荐–d9–t9参数防止路由僵死reaver-imon0-bMAC-a-S–d9–t9-vv)小结-学习时应因状况调整参数(-c后面都已目标频道为1作为例子)目标信号非常好: reaver -i mon0 -bMAC -a -S -vv -d0 -c1目标信号普通: reaver -i mon0 -bMAC

    2022年5月4日
    107
  • linux 服务器端配置nfs(配置samba服务器步骤)

    一、NFS服务简介  NFS是NetworkFileSystem的缩写,即网络文件系统。一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布。功能是通过网络让不同的机器、不同的操作系统能够彼此分享个别的数据,让应用程序在客户端通过网络访问位于服务器磁盘中的数据,是在类Unix系统间实现磁盘文件共享的一种方法。  NFS的基本原则是“容许不同的客户端及服务端

    2022年4月13日
    130
  • Java解析XML文件的四种方法「建议收藏」

    Java解析XML文件的四种方法「建议收藏」【摘要】可扩展标志语言(XML)在实现信息标准化、信息的交流与共享上有其独特的技术优势,因此受到了广泛的重视。本文先简单的介绍了XML基本知识,然后从XML应用入手总结了四种现今最常见的XML的解析方法,介绍了这四种方法的特点,其中包括优点与不足之处。最后给出了一个简单的案例来对这四种解析进行代码介绍。【关键字】XML文件,DOM,SAX,JDOM,DOM4J【引言】XML即可扩展标记语

    2022年6月3日
    45
  • 一阶惯性环节的传递函数表达式_设一力传感器可作为二阶系统来处理

    一阶惯性环节的传递函数表达式_设一力传感器可作为二阶系统来处理具有纯滞后一阶惯性系统计算机控制系统设计具体内容:1)自己给出系统的闭环传递函数的表达式2)自己设定系统性能指标3)书面设计一个计算机控制系统的硬件布线连接图4)硬件布线连接图转化为系统结构图5)选择一种控制算法6)软件工程知识编写程序流程图7)在MATLAB下进行编程和仿真,给出单位阶跃函数的输出结果表8)进行系统的可靠性和抗干扰性的分析计算机控制系统课程设计目录…

    2022年9月1日
    1
  • 安卓root权限管理_root权限在哪里设置

    安卓root权限管理_root权限在哪里设置Android权限说明Android系统是运行在Linux内核上的,Android与Linux分别有自己的一套严格的安全及权限机制,Android系统权限相关的内容,(一)linux文件系统上的权限-rwxr-x–xsystemsystem41562012-06-3016:12test.apk.代表的是相应的用户/用户组及其他人对此文件的访问权限,与此文件运行起来

    2025年6月28日
    1
  • SOAP UI 使用

    SOAP UI 使用

    2021年7月2日
    84

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号