[PyQT5] QFileDialog窗口关闭时主窗口也关闭

新手,在尝试写一个pyqt5的小软件。

现在是要点击button后,出现QFileDialog文件对话框,打开文件或保存文件

但是debug时点击button,打开对话框,点击关掉对话框或取消选择时,整个界面都会退出,只有Process finished with exit code 1的提示

我希望关闭窗口时,主窗口不能被影响,请问哪里出错?

以下是相关代码

    def __init__(self,parent=None):

        #button clicked
        self.loadFileButton.clicked.connect(self.loadFile)
        self.generateButton.clicked.connect(self.generateFile)




    #loadFileButton 加载配置文件到textEdit
    def loadFile(self):
        path = QFileDialog.getOpenFileName(self,
                                                '加载配置文件',
                                                '',
                                                'Python (*.py)')
        f = open(path[0],'r+',encoding='UTF-8')
        with f:
            self.data = "".join(f.readlines())
            self.textEdit.setText(self.data)

    #generateButton 保存配置文件
    def generateFile(self):
        self.data = self.textEdit.toPlainText()
        path = QFileDialog.getSaveFileName(self,
                                               "保存配置文件",
                                               '',
                                               'Python (*.py)')
        with open(path[0],'w',encoding='UTF-8') as f:
            f.write(self.data)

2个回答

你试试path = QFileDialog.getOpenFileName(filter='Python (*.py)')

如果不行,你试下try来检查错误,不会直接退出

def loadFile(self):
        try:
                    path = QFileDialog.getOpenFileName(filter='Python (*.py)')
                    f = open(path[0],'r+',encoding='UTF-8')
                    with f:
                            self.data = "".join(f.readlines())
                            self.textEdit.setText(self.data)
        except Exception as e:
           print(e)

这样就应该不会报错了

path = QFileDialog.getOpenFileName(filter='Python (*.py)')
if path!="":
    f = open(path[0],'r+',encoding='UTF-8')
    with f:
        self.data = "".join(f.readlines())
        self.textEdit.setText(self.data)
weixin_39416561
lyhsdy 回复pannnsy: 如果答案对你有帮助,麻烦采纳下
一年多之前 回复
pannnsy
pannnsy 回复weixin_39416561: 超级感谢~解决啦
一年多之前 回复
weixin_39416561
lyhsdy 回复pannnsy: 更新了代码了,你看下
一年多之前 回复
pannnsy
pannnsy 用try时抛出错误:[Errno 2] No such file or directory: ''
一年多之前 回复

楼上是OK的,不过其实要把path变成str之后,if语句才有效,因为QFileDialog.getOpenFileName返回的是tuple(filename, filters)

代码如下

    def loadFile(self):
        path,_ = QFileDialog.getOpenFileName(self,"加载配置文件",'','Python (*.py)')
        if path == '':
            pass
        else:
            f = open(path, 'r+', encoding='UTF-8')
            with f:
                self.data = "".join(f.readlines())
                self.textEdit.setText(self.data)

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
pyqt5 getOpenFilename 函数总是出现bug,请问应该怎么更改?

class Ui_Second(object): def setupUi(self, Dialog): Dialog.setObjectName("Secondwindow") Dialog.resize(1065, 791) Dialog.setSizeGripEnabled(True) self.label = QtWidgets.QLabel(Dialog) self.label.setGeometry(QtCore.QRect(70, 60, 81, 18)) self.label.setObjectName("label") self.verticalLayoutWidget = QtWidgets.QWidget(Dialog) self.verticalLayoutWidget.setGeometry(QtCore.QRect(150, 230, 401, 371)) self.verticalLayoutWidget.setObjectName("verticalLayoutWidget") self.verticalLayout = QtWidgets.QVBoxLayout(self.verticalLayoutWidget) self.verticalLayout.setContentsMargins(0, 0, 0, 0) self.verticalLayout.setObjectName("verticalLayout") self.label_3 = QtWidgets.QLabel(self.verticalLayoutWidget) self.label_3.setObjectName("label_3") self.verticalLayout.addWidget(self.label_3) self.label_4 = QtWidgets.QLabel(self.verticalLayoutWidget) self.label_4.setObjectName("label_4") self.verticalLayout.addWidget(self.label_4) self.label_6 = QtWidgets.QLabel(self.verticalLayoutWidget) self.label_6.setObjectName("label_6") self.verticalLayout.addWidget(self.label_6) self.label_5 = QtWidgets.QLabel(self.verticalLayoutWidget) self.label_5.setObjectName("label_5") self.verticalLayout.addWidget(self.label_5) self.label_2 = QtWidgets.QLabel(self.verticalLayoutWidget) self.label_2.setObjectName("label_2") self.verticalLayout.addWidget(self.label_2) self.verticalLayoutWidget_2 = QtWidgets.QWidget(Dialog) self.verticalLayoutWidget_2.setGeometry(QtCore.QRect(679, 230, 281, 371)) self.verticalLayoutWidget_2.setObjectName("verticalLayoutWidget_2") self.verticalLayout_2 = QtWidgets.QVBoxLayout(self.verticalLayoutWidget_2) self.verticalLayout_2.setContentsMargins(0, 0, 0, 0) self.verticalLayout_2.setObjectName("verticalLayout_2") self.pushButton_2 = QtWidgets.QPushButton(self.verticalLayoutWidget_2) self.pushButton_2.setObjectName("pushButton_2") self.verticalLayout_2.addWidget(self.pushButton_2) self.pushButton_4 = QtWidgets.QPushButton(self.verticalLayoutWidget_2) self.pushButton_4.setObjectName("pushButton_4") self.verticalLayout_2.addWidget(self.pushButton_4) self.pushButton_5 = QtWidgets.QPushButton(self.verticalLayoutWidget_2) self.pushButton_5.setObjectName("pushButton_5") self.verticalLayout_2.addWidget(self.pushButton_5) self.pushButton_3 = QtWidgets.QPushButton(self.verticalLayoutWidget_2) self.pushButton_3.setObjectName("pushButton_3") self.verticalLayout_2.addWidget(self.pushButton_3) self.pushButton = QtWidgets.QPushButton(self.verticalLayoutWidget_2) self.pushButton.setObjectName("pushButton") self.verticalLayout_2.addWidget(self.pushButton) self.pushButton_6 = QtWidgets.QPushButton(Dialog) self.pushButton_6.setGeometry(QtCore.QRect(770, 640, 141, 81)) self.pushButton_6.setObjectName("pushButton_6") self.retranslateUi(Dialog) QtCore.QMetaObject.connectSlotsByName(Dialog) self.pushButton_2.clicked.connect(self.openfile) def openfile(self): filename,_ = QFileDialog.getOpenFileName(self, 'a'); self.label_3.setText(filename) 错误是![图片说明](https://img-ask.csdn.net/upload/201710/20/1508507882_699491.png)

python PYQT5 UI窗口突然自动关闭

我想通过获得输入的数据传给函数,然后再利用函数输出想要的结果到tableView中。函数能print出结果,但传入tableView中时UI界面就突然自动关闭了。 烦请大神出手相助,谢谢! 代码如下: ``` #读取数据 db = pd.read_excel('C:/Users/Documents/Project/SQL/TBFA.xlsx') class Where_Failed_PN(QWidget): def __init__(self): super(Where_Failed_PN, self).__init__() self.ui = Ui_Where_Units() self.ui.setupUi(self) # 装载所有初始数据 modeldf = pandasModel(db) self.ui.dataTable.setModel(modeldf) #在label上显示输入UI窗口输入的数据 self.ui.PNedit.textEdited.connect(self.showText) input=self.ui.PNedit.sender() self.ui.PNlable.setText(input) self.ui.PNedit.editingFinished.connect(self.inputText) self.ui.getBtn.clicked.connect(self.inputText) def showText(self,Text): self.ui.PNlable.setText(Text) self.ui.PNlable.adjustSize() def inputText(self): self.ui.PNedit.end(True) inputText = self.ui.PNlable.text() #函数输出结果 PNdata = db[(db['PartNum'] == inputText)] print(PNdata)#在终端能显示结果,但UI窗口自动关闭了 #希望将结果显示在UI的tableView中 modeldf = pandasModel(PNdata) self.ui.dataTable.setModel(modeldf) if __name__ == '__main__': app = QApplication(sys.argv) main = Where_Failed_PN() main.show() sys.exit(app.exec_()) ```

pyqt5运行后没有显示窗口

![图片说明](https://img-ask.csdn.net/upload/201903/28/1553768986_839067.png) 第一次使用pyqt5,理想情况应该是弹出一个空的窗口才对啊,但程序运行完以后什么都没有发生,难道我还漏了什么东西吗?

pyqt5开发的GUI程序怎么打包?程序运行的时候不会出现dos窗口

如题,pyqt5开发的GUI程序(python3.4)用什么软件打包比较合适? 打包后程序运行的时候怎么让他不会出现dos窗口,只显示GUI窗口![图片说明](https://img-ask.csdn.net/upload/201606/22/1466599956_694106.jpg)

PyQt5 使用QPlainText显示日志内容,现在多个窗口的日志内容混在一起

用print打印日志内容,然后把sys.stdout重定向到QPlainText的输入中,但是存在的问题是,我再新建一个窗口,两个窗口的日志内容会混在一起,请问应该怎么解决?

eric6 pyqt5 怎么实现类似qq聊天窗口的合并

我最近在搞一个类似window上的qq聊天工具, 有几个问题想求教大神们!!! 用显示框显示上线人,那怎么实现显示宽可以点击,然后发出信号,弹出窗口, 还有就是,怎么实现窗口的合并! 求教大神啊!!!!

PyQt5关于QThread线程阻塞以及UI界面假死的问题

界面有两个按钮,一个启动QThread线程,一个启动threading.Thread线程,做的同样的工作,模拟耗时操作。代码如下: ``` import sys, os import threading import time import PyQt5.QtWidgets as qtw from PyQt5.QtCore import QThread from PyQT5.test import Ui_MainWindow class MyWindow(qtw.QMainWindow, Ui_MainWindow): def __init__(self): super().__init__() self.setupUi(self) self.btn_begin1.clicked.connect(startWork1) self.btn_begin2.clicked.connect (startWork2) self.show () class MyThread(QThread): # signal = pyqtSignal(int) def __init__(self): super().__init__() def __del__(self): self.wait() def run(self): print("run") work(15) def startWork1(): thread = MyThread() print ("start") thread.start () print ("start finish") def startWork2(): threading.Thread(target=work, args=(15,)).start() def work(n): print ("work") for i in range(1, n+1): print(str(i)+": do something...") time.sleep(1) if __name__ == "__main__": app = qtw.QApplication(sys.argv) w = MyWindow() app.exec_ () ``` 问题1:点击按钮1启动Qthread,5秒后UI界面出现假死,点击按钮2启动threading.Thread不会出现假死 问题2:在MyThread中把def __del__(self):self.wait()这个方法删除后,正常运行程序闪退,没有运行到run()方法,以debug方式运行,能正常运行,且点击按钮1时不会出现UI界面假死 我的环境为python3.6 pyqt5-5.13.0 pycharm2017.3 请教下是什么原因造成上述两个问题。

请问各位大佬:如何保存pyqt5界面的内容并在下次打开界面时显示保存的内容?

举个例子:界面A中有文本输入框、下拉框等控件,并相应地输入有文本、下拉选项等。 现需要关闭界面A,然后在下一次打开界面A时能够自动地显示前面的输入内容。 请问各位大佬如何能实现上述功能!感谢!

pyqt5的QVideoWidget视频播放问题?

import sys from PyQt5.QtCore import QUrl from PyQt5.QtMultimedia import QMediaPlayer, QMediaContent, QMediaPlaylist from PyQt5.QtMultimediaWidgets import QVideoWidget from PyQt5.QtWidgets import QApplication, QWidget class Demo(QWidget): def __init__(self): super(Demo, self).__init__() self.playlist = QMediaPlaylist(self) #实例化一个播放列表 self.video_widget = QVideoWidget(self) #实例化一个视频窗口对象 self.video_widget.resize(self.width(), self.height())#设置视频窗口的大小 self.player = QMediaPlayer(self) #实例化一个播放器 self.player.setPlaylist(self.playlist) #给播放器设置播放列表 self.player.setVideoOutput(self.video_widget) # 设置播放设备。播放设备是视频窗口对象 self.playlist.addMedia(QMediaContent(QUrl.fromLocalFile(r'D:\ss\ssss\images\video1.mp4'))) # 给播放列表添加视频源 self.playlist.addMedia(QMediaContent(QUrl.fromLocalFile(r'D:\ss\ssss\images\video2.mp4'))) self.playlist.addMedia(QMediaContent(QUrl.fromLocalFile(r'D:\ss\ssss\images\video3.mp4'))) self.playlist.setPlaybackMode(QMediaPlaylist.Loop) #设置播放模式 # QMediaPlaylist.CurrentItemOnce=0 当前内容播放一次 #QMediaPlaylist.CurrentItemInLoop=1 单曲循环 #QMediaPlaylist.Sequential=2 顺序播放 # QMediaPlaylist.Loop=3 列表循环 # QMediaPlaylist.Random=4 随机播放 self.playlist.setCurrentIndex(1) # 设置当前要进行播放文件,传入1代表播放第2个文件 self.player.setVolume(80) #设置音量 self.player.play() #播放 if __name__ == '__main__': app = QApplication(sys.argv) demo = Demo() demo.show() sys.exit(app.exec_()) ``` 没有播放,不知道问题在哪儿? ```

pyqt5如何弹出多个界面心事多组不同的数据

我这里有多组数据需要展示,展示的界面是在alert.py中写的,现在我想弹出多个界面,其中每个界面展示一组数据。现在的结果是alert.py可以接收到传过来的数据,界面也能弹出,但是界面上没有显示出数据,而且我的弹框线程无法将数据和界面一一对应起来,我想请问一下这是什么原因? main.py ``` from PyQt5 import * from PyQt5.QtGui import * from PyQt5.QtCore import * from PyQt5.QtWidgets import * import sys import time from alert import Show_Text from change import Show_Change import winsound class Ui_Control_system(object): def setupUi(self, Control_system): Control_system.setObjectName("Control_system") Control_system.resize(1004, 722) Control_system.setFixedSize(1004, 722) Control_system.setWindowIcon(QIcon('images/icon.png')) Control_system.setStyleSheet("QMainWindow{border-image:url(images/background.jpg)}") self.centralwidget = QWidget(Control_system) self.centralwidget.setObjectName("centralwidget") self.pushButton_skip = QPushButton(self.centralwidget) self.pushButton_skip.setGeometry(QRect(70, 60, 121, 41)) self.pushButton_skip.setObjectName("pushButton_skip") Control_system.setCentralWidget(self.centralwidget) self.statusbar = QStatusBar(Control_system) self.statusbar.setObjectName("statusbar") Control_system.setStatusBar(self.statusbar) self.retranslateUi(Control_system) QMetaObject.connectSlotsByName(Control_system) def retranslateUi(self, Control_system): _translate = QCoreApplication.translate Control_system.setWindowTitle(_translate("Control_system", "实时监控系统")) self.pushButton_skip.setText(_translate("Control_system", "跳转")) class Control_system(QMainWindow, Ui_Control_system): #alarmQueue = queue.LifoQueue() def __init__(self, parent=None): super().__init__(parent) self.setupUi(self) self.add_data_list = "" self.pushButton_skip.clicked.connect(self.jump_to_alert) self._alerts = [] @pyqtSlot() def jump_to_alert(self): self.popup_window_thread = PopupWindow(self) self.popup_window_thread.popup.connect(self.goAlert) self.popup_window_thread.start() @pyqtSlot() def jump_to_change(self): self.change_window_thread = ChangeWindow(self) self.change_window_thread.change_signal.connect(self.goChange) self.change_window_thread.start() def goAlert(self): self.add_data_list = [["1","2","3"],["4","5","6"]] for term in self.add_data_list: alert = Alert() alert.some_room = term[0] alert.some_machine = term[1] alert.some_project = term[2] print(alert.some_project) alert.show() self._alerts.append(alert) class Alert(Show_Text): def __init__(self): super().__init__() #self.setupUi(self) def closeEvent(self, event): reply = QMessageBox.question(self, '警告', "是否要退出警告?", QMessageBox.Yes | QMessageBox.No, QMessageBox.No) if reply == QMessageBox.Yes: event.accept() else: event.ignore() class PopupWindow(QThread): popup = pyqtSignal() def __init__(self, parent=None): super(PopupWindow, self).__init__() self.index = 0 def run(self): while self.index <= 1: self.index +=1 self.popup.emit() time.sleep(1) def stop(self): self.quit() self.wait() if __name__ == '__main__': if not QApplication.instance(): app = QApplication(sys.argv) else: app = QApplication.instance() w = Control_system() w.show() sys.exit(app.exec()) ``` alert.py ``` from PyQt5 import * from PyQt5.QtGui import * from PyQt5.QtCore import * from PyQt5.QtWidgets import * import time class Ui_Dialog(object): def setupUi(self, Dialog): Dialog.setObjectName("Dialog") Dialog.resize(557, 444) #Dialog.setStyleSheet("QDialog{border-image:url(images/background.jpg)}") Dialog.setWindowIcon(QIcon('images/icon.png')) self.textBrowser = QtWidgets.QTextBrowser(Dialog) self.textBrowser.setGeometry(QtCore.QRect(200, 80, 256, 41)) self.textBrowser.setObjectName("textBrowser") self.textBrowser_2 = QtWidgets.QTextBrowser(Dialog) self.textBrowser_2.setGeometry(QtCore.QRect(200, 170, 256, 41)) self.textBrowser_2.setObjectName("textBrowser_2") self.textBrowser_3 = QtWidgets.QTextBrowser(Dialog) self.textBrowser_3.setGeometry(QtCore.QRect(200, 260, 256, 41)) self.textBrowser_3.setObjectName("textBrowser_3") self.label = QtWidgets.QLabel(Dialog) self.label.setGeometry(QtCore.QRect(60, 80, 111, 31)) font = QtGui.QFont() font.setFamily("微软雅黑") font.setPointSize(20) font.setBold(True) font.setWeight(75) self.label.setFont(font) self.label.setStyleSheet("color: rgb(255, 0, 0);") self.label.setTextFormat(QtCore.Qt.AutoText) self.label.setObjectName("label") self.label_2 = QtWidgets.QLabel(Dialog) self.label_2.setGeometry(QtCore.QRect(60, 170, 111, 31)) font = QtGui.QFont() font.setFamily("微软雅黑") font.setPointSize(20) font.setBold(True) font.setWeight(75) self.label_2.setFont(font) self.label_2.setStyleSheet("color: rgb(255, 0, 0);") self.label_2.setTextFormat(QtCore.Qt.AutoText) self.label_2.setObjectName("label_2") self.alert = QtWidgets.QLabel(Dialog) self.alert.setGeometry(QtCore.QRect(60, 260, 111, 31)) font = QtGui.QFont() font.setFamily("微软雅黑") font.setPointSize(20) font.setBold(True) font.setWeight(75) self.alert.setFont(font) self.alert.setStyleSheet("color: rgb(255, 0, 0);") self.alert.setTextFormat(QtCore.Qt.AutoText) self.alert.setObjectName("alert") self.retranslateUi(Dialog) def retranslateUi(self, Dialog): _translate = QtCore.QCoreApplication.translate Dialog.setWindowTitle(_translate("Dialog", "警告")) self.label.setText(_translate("Dialog", "报警车间")) self.label_2.setText(_translate("Dialog", "报警机器")) self.alert.setText(_translate("Dialog", "报警项目")) class Show_Text(QDialog, Ui_Dialog): def __init__(self, parent=None): super().__init__(parent) self.some_room = "" self.some_machine = "" self.some_project = "" print(self.some_room) print(self.some_machine) print(self.some_project) self.setupUi(self) self.show_text_thread = showtext_Thread(self.some_room,self.some_machine,self.some_project) self.show_text_thread.start() @pyqtSlot(str, str, str) def show_Data(self, room, machine, project):#数据更新 self.textBrowser.append(room) self.textBrowser_2.append(machine) self.textBrowser_3.append(project) class showtext_Thread(QtCore.QThread): trigger = QtCore.pyqtSignal(str,str,str) def __init__(self, room, machine, project, parent=None): super(showtext_Thread, self).__init__(parent) self.thread_room = room self.thread_machine = machine self.thread_project = project def run(self): print(self.thread_room) self.trigger.emit(self.thread_room,self.thread_machine,self.thread_project) time.sleep(1) def stop(self): self.quit() self.wait() ```

python pyqt5 怎样暂停和退出指定线程?

![图片说明](https://img-ask.csdn.net/upload/201810/05/1538742487_875554.png) 怎样在点击界面的按钮暂停 或 停止 来控制线程的暂停或停止 我写的代码如下,请大神们指导下添加什么方法来控制线程 ``` # -*- coding: utf-8 -*- # Form implementation generated from reading ui file 'test1.ui' # # Created by: PyQt5 UI code generator 5.11.2 # # WARNING! All changes made in this file will be lost! from PyQt5 import QtCore, QtGui, QtWidgets import time import threading import sys import os class Ui_Dialog(object): def setupUi(self, Dialog): Dialog.setObjectName("Dialog") Dialog.resize(387, 288) self.listWidget = QtWidgets.QListWidget(Dialog) self.listWidget.setGeometry(QtCore.QRect(110, 30, 256, 192)) self.listWidget.setVerticalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOn) self.listWidget.setHorizontalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOn) self.listWidget.setObjectName("listWidget") self.widget = QtWidgets.QWidget(Dialog) self.widget.setGeometry(QtCore.QRect(20, 40, 77, 83)) self.widget.setObjectName("widget") self.verticalLayout = QtWidgets.QVBoxLayout(self.widget) self.verticalLayout.setContentsMargins(0, 0, 0, 0) self.verticalLayout.setObjectName("verticalLayout") self.pushButton = QtWidgets.QPushButton(self.widget) self.pushButton.setObjectName("pushButton") self.verticalLayout.addWidget(self.pushButton) self.pushButton_2 = QtWidgets.QPushButton(self.widget) self.pushButton_2.setObjectName("pushButton_2") self.verticalLayout.addWidget(self.pushButton_2) self.pushButton_3 = QtWidgets.QPushButton(self.widget) self.pushButton_3.setObjectName("pushButton_3") self.verticalLayout.addWidget(self.pushButton_3) self.retranslateUi(Dialog) QtCore.QMetaObject.connectSlotsByName(Dialog) def retranslateUi(self, Dialog): _translate = QtCore.QCoreApplication.translate Dialog.setWindowTitle(_translate("Dialog", "Dialog")) self.pushButton.setText(_translate("Dialog", "开始")) self.pushButton_2.setText(_translate("Dialog", "暂停")) self.pushButton_3.setText(_translate("Dialog", "停止")) class Dialog(QtWidgets.QDialog): def closeEvent(self, event): reply = QtWidgets.QMessageBox.question(self, '本程序', "是否要退出程序?", QtWidgets.QMessageBox.Yes | QtWidgets.QMessageBox.No, QtWidgets.QMessageBox.No) if reply == QtWidgets.QMessageBox.Yes: event.accept() os._exit(0) else: event.ignore() class myThread(threading.Thread): def __init__(self, ui): threading.Thread.__init__(self) self.ui = ui self.counter = 0 def run(self): a = 0 while True: a+=1 print(a) self.ui.listWidget.addItem(str(a)) time.sleep(1) def main(): """ 主函数,用于运行程序 :return: None """ app = QtWidgets.QApplication(sys.argv) dialog = Dialog() # 注意修改为了自己重写的Dialog类 ui = Ui_Dialog() ui.setupUi(dialog) dialog.show() # 显示了自己重写的Dialog类 thread1 = myThread(ui) thread1.start() sys.exit(app.exec_()) if __name__ == '__main__': main() ```

pyqt5 使用多线程进行socket通信,界面未响应后程序退出

本来准备开好几个线程通信,写了两个正常运行,加了第三个后界面未响应,pycharm报错Process finished with exit code -1073740791 (0xC0000409) 现在一个线程也这样,不知是哪里出了问题。 这是UI类函数 class TabDemo(QTabWidget,QMainWindow): def __init__(self,parent=None): super(TabDemo,self).__init__(parent) self.resize(1200,900) self.tab1 = QWidget() self.tab2 = QWidget() self.tab3 = QWidget() self.tab4 = QWidget() self.tab5 = QWidget() self.addTab(self.tab1,'Voltage Curent') self.addTab(self.tab2,'Parameters') self.addTab(self.tab3,'Waveforms') self.addTab(self.tab4,'Charts') self.addTab(self.tab5,'Save Load') self.tab1UI() self.tab2UI() self.tab3UI() self.tab4UI() self.tab5UI() # self.Tcptrans = TcpThread() # self.Tcptrans1 = TcpThread1() # self.Tcptrans2 = TcpThread2() self.Tcptrans3 = TcpThread3() # self.Tcptrans.start() # self.Tcptrans1.start() # self.Tcptrans2.start() self.Tcptrans3.start() # self.Tcptrans.sinOut.connect(self.display) # self.Tcptrans1.sinOut1.connect(self.display1) # self.Tcptrans2.sinOut2.connect(self.display2) self.Tcptrans3.sinOut3.connect(self.display3) self.setWindowTitle('电能质量监测系统') 这是tab2UI def tab2UI(self): grid = QGridLayout() grid.setSpacing(10) l1=QLabel('Parameters') l2=QLabel('24V Supply') l3=QLabel('Volts') l4=QLabel('DSP Temp') l5=QLabel('Dg.c') self.t1=QTextBrowser() self.t2=QTextBrowser() self.table=QTableWidget(9,20) self.g1=QGraphicsView() self.table.setVerticalHeaderLabels(['ReactivePowerA', 'ReactivePowerC', 'ActivePowerA', 'ActivePowerC','CurrentA','CurrentC','THD IA', 'THD IC','Meter ID']) ''' self.l1.setGeometry(QtCore.QRect(190, 10, 101, 16)) self.l2.setGeometry(QtCore.QRect(50, 30, 91, 16)) self.l3.setGeometry(QtCore.QRect(170, 60, 72, 15)) self.l4.setGeometry(QtCore.QRect(50, 130, 72, 15)) self.l5.setGeometry(QtCore.QRect(170, 170, 72, 15)) self.t1.setGeometry(QtCore.QRect(30, 50, 111, 31)) self.t2.setGeometry(QtCore.QRect(30, 160, 111, 31)) self.table.setGeometry(QtCore.QRect(100, 20, 871, 291)) ''' grid.addWidget(l1,1,3) grid.addWidget(self.g1,2,0,5,16) grid.addWidget(l2,2,17) grid.addWidget(self.t1,3,17) grid.addWidget(l3,3,18) grid.addWidget(l4,4,17) grid.addWidget(self.t2,5,17) grid.addWidget(l5,5,18) grid.addWidget(self.table,6,0,20,21) self.tab2.setLayout(grid) 这是槽函数 def display3(self,Meterreading): for i in range(9): for j in range(20): self.Item=QTableWidgetItem('%s' % Meterreading[i,j]) self.table.setItem(i,j,self.Item) 这是定义的子线程类class TcpThread3(QThread): sinOut3 = pyqtSignal(np.ndarray) def __init__(self, parent=None): super(TcpThread3, self).__init__(parent) self.working = True def __del__(self): # 线程状态改变与线程终止 self.working = False self.wait() def run(self): if self.working == True: self.tcp_client_socket2 = socket(AF_INET, SOCK_STREAM) self.tcp_client_socket2.connect(("127.0.0.1", 6666)) while self.working == True: self.meg3 = b'\x01\x09\x00\x00\x01\x68\xDD\xB5' self.tcp_client_socket3.send(self.meg3) self.recv_data3 = self.tcp_client_socket3.recv(1024) l3 = list() l4 = list() CT = 1 PT = 1 for i in range(3, 723, 2): temp = self.recv_data3[i:i + 2] result = struct.unpack('!h', temp)[0] l3.append(result) list4 = l3[0:320] a = np.array(list4).reshape(20, 16) for i in range(10): l4.append(a[..., i]) ReactivePowerA = l4[0] * 0.0001 * CT * PT ReactivePowerC = l4[1] * 0.0001 * CT * PT ActivePowerA = l4[2] * 0.0001 * CT * PT ActivePowerC = l4[3] * 0.0001 * CT * PT CurrentA = l4[4] * 0.01 * CT CurrentC = l4[5] * 0.01 * CT THDIA = l4[6] * 0.1 THDIC = l4[7] * 0.1 lastone = (a[..., 8] * 65536 + a[..., 9]) * 0.01 Meterreading = np.vstack((ReactivePowerA, ReactivePowerC, ActivePowerA, ActivePowerC, CurrentA, CurrentC, THDIA, THDIC, lastone)) self.sinOut3.emit(Meterreading) QApplication.processEvents() self.sleep(1)

为什么我import PyQt5.QtWidgets后程序就退出了

我在使用PyQt5时,不能import PyQt5.QtWidgets,无论是 ```python import PyQt import PyQt5.QtWidgets ``` 还是 ```python from PyQt5 import QtWidgets ``` 以及 ```python from PyQt5.QtWidgets import (一个存在的东西) ``` 都会直接退出程序 ![image.png](https://i.loli.net/2020/05/08/ySl8FJdOgVM5147.png) 重装过了好多次了,都不好使 请问这应该怎么做 我突然发现了一个诡异的实时,在VSCode里运行就行不通,但在cmd里就行得通,有哪位大神能解答一下吗?

pyqt-tools和pyqt5的版本对应问题

RT,pip安装pyqt5的最新版本是5.15;而pip安装pyqt-tools最新版本是5.13,除了降级pyqt5还有其他方法吗?

pyinstaller或cx_freeze打包pyqt5程序的问题

环境: python3.4.4 pyqt5 qt5.5.1 win10 x64 python写的pyqt5程序需要转换成exe,用cxfreeze打包可以正常运行,但是输出文件太大,就一个小的GUI程序就超过200m了,google也有一些说法总之就是很难办。 用pyinstaller打包以后程序体积比较小只有30来兆,但是又无法运行,点击exe提示fail to execute script ……也没提示更多信息,我查google说是要加入pyqt5的路径,但是我电脑PyQt5的文件夹没有网上说的qt\bin这个路径,我就直接加的“C:\Python34\Lib\site-packages\PyQt5”这个路径,打包出来能看到pyqt5的一些组件,但是exe还是无法运行。 ……总之cxfreeze体积太大,pyinstaller无法运行,不知道咋办了…… 感觉python作为一个比较成熟的东西,为什么在打包exe这么基础的功能上反而不成熟。

给以前写的一个python程序,用pyqt5加了gui但多进和无响应

之前学python时写了个爬虫。就是捉些商品的标题,介绍,价格,还有买家评论。 今天想学学pyqt5,于是想直接给这爬虫加个gui好了。 运行后,主窗体无响应。 觉得可能是爬虫的问题,太耗时。 于是在pyqt5里的按钮方法里,加了个进程。 当点按钮时,打开一个新进程执行爬虫。 爬虫虽然能正常运行,但gui还是会无响应。 不明白这是怎么回事? 谢谢 ``` class MyWindow(QMainWindow, Ui_MainWindow): def __init__(self, parent=None): super(MyWindow, self).__init__(parent) self.setupUi(self) self.pushButton_2.clicked.connect(self.aa) def aa(self): p = Process(target=pa) p.start() p.join() if __name__ == '__main__': app = QApplication(sys.argv) m = MyWindow() m.show() sys.exit(app.exec_()) ```

PyQt5的QListView多选返回值

代码如下,怎么样实现多选返回列表,显示在QLabel ![图片说明](https://img-ask.csdn.net/upload/201812/03/1543834681_373537.gif) ``` import sys from PyQt5.QtWidgets import QApplication,QWidget,QVBoxLayout,QListView,QAbstractItemView from PyQt5.QtCore import QStringListModel from PyQt5 import QtWidgets class ListViewDemo(QWidget): def __init__(self,parent=None): super(ListViewDemo, self).__init__(parent) #设置初始大小与标题 self.resize(300,270) self.setWindowTitle('QListView 多选问题') #垂直布局 self.layout=QVBoxLayout() #实例化列表视图 self.listview=QListView() #实例化列表模型,添加数据 self.slm=QStringListModel() self.qList=['Item 1','Item 2','Item 3','Item 4','Item 5','Item 6','Item 7','Item 8','Item 9'] #设置模型列表视图,加载数据列表 self.slm.setStringList(self.qList) #设置列表视图的模型 self.listview.setModel(self.slm) # 多选 self.listview.setSelectionMode(QAbstractItemView.ExtendedSelection) # 不能对表格进行修改(双击重命名等) self.listview.setEditTriggers(QAbstractItemView.NoEditTriggers) self.label_dqxz = QtWidgets.QLabel() self.label_dqxz.setText("当前选择:-") #单击触发自定义的槽函数 self.listview.clicked.connect(self.clicked) #设置窗口布局,加载控件 self.layout.addWidget(self.listview) self.layout.addWidget(self.label_dqxz) self.setLayout(self.layout) def clicked(self,index): self.label_dqxz.setText('当前选择:'+self.qList[index.row()]) if __name__ == '__main__': app=QApplication(sys.argv) win=ListViewDemo() win.show() sys.exit(app.exec_()) ```

python2.7如何安装pyqt5-tools

在使用pip install python-qt5可以成功安装pyqt5,但无法安装pyqt5-tools

Anaconda下如何离线安装Pyqt5 并使用PyQt designer?

Python新手(使用Anaconda学习中)求教各路大神: 1.因某些原因,电脑无法直接联网,需要离线安装各种软件、模块,请问Anaconda下如何离线安装Pyqt5 并使用PyQt designer,以实现GUI编程? 2.网上多为Anaconda+Pycharm+PyQt或Anaconda3 + PyQt5 + Eric6安装,请问Anaconda+PyQt下,Pycharm或Eric是必须的吗?Anacondat和Pycharm是什么关系?

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

课程主要面向嵌入式Linux初学者、工程师、学生 主要从一下几方面进行讲解: 1.linux学习路线、基本命令、高级命令 2.shell、vi及vim入门讲解 3.软件安装下载、NFS、Samba、FTP等服务器配置及使用

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

Python代码实现飞机大战

文章目录经典飞机大战一.游戏设定二.我方飞机三.敌方飞机四.发射子弹五.发放补给包六.主模块 经典飞机大战 源代码以及素材资料(图片,音频)可从下面的github中下载: 飞机大战源代码以及素材资料github项目地址链接 ————————————————————————————————————————————————————————— 不知道大家有没有打过飞机,喜不喜欢打飞机。当我第一次接触这个东西的时候,我的内心是被震撼到的。第一次接触打飞机的时候作者本人是身心愉悦的,因为周边的朋友都在打飞机, 每

Python数据分析与挖掘

92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元 &nbsp; 为什么学习数据分析? &nbsp; &nbsp; &nbsp; 人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。 &nbsp; &nbsp; &nbsp; 从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。 &nbsp;&nbsp; 本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。 &nbsp; 二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。 &nbsp; 三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。 &nbsp; 四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。 &nbsp; 五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。

如何在虚拟机VM上使用串口

在系统内核开发中,经常会用到串口调试,利用VMware的Virtual Machine更是为调试系统内核如虎添翼。那么怎么搭建串口调试环境呢?因为最近工作涉及到这方面,利用强大的google搜索和自己

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:csdn590)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

北京师范大学信息科学与技术学院笔试10复试真题

北京师范大学信息科学与技术学院笔试,可以更好的让你了解北师大该学院的复试内容,获得更好的成绩。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Python界面版学生管理系统

前不久上传了一个控制台版本的学生管理系统,这个是Python界面版学生管理系统,这个是使用pycharm开发的一个有界面的学生管理系统,基本的增删改查,里面又演示视频和完整代码,有需要的伙伴可以自行下

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

Tomcat服务器下载、安装、配置环境变量教程(超详细)

未经我的允许,请不要转载我的文章,在此郑重声明!!! 请先配置安装好Java的环境,若没有安装,请参照我博客上的步骤进行安装! 安装Java环境教程https://blog.csdn.net/qq_40881680/article/details/83585542 Tomcat部署Web项目(一)·内嵌https://blog.csdn.net/qq_40881680/article/d...

2019数学建模A题高压油管的压力控制 省一论文即代码

2019数学建模A题高压油管的压力控制省一完整论文即详细C++和Matlab代码,希望对同学们有所帮助

图书管理系统(Java + Mysql)我的第一个完全自己做的实训项目

图书管理系统 Java + MySQL 完整实训代码,MVC三层架构组织,包含所有用到的图片资源以及数据库文件,大三上学期实训,注释很详细,按照阿里巴巴Java编程规范编写

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

微信小程序开发实战之番茄时钟开发

微信小程序番茄时钟视频教程,本课程将带着各位学员开发一个小程序初级实战类项目,针对只看过官方文档而又无从下手的开发者来说,可以作为一个较好的练手项目,对于有小程序开发经验的开发者而言,可以更好加深对小程序各类组件和API 的理解,为更深层次高难度的项目做铺垫。

[已解决]踩过的坑之mysql连接报“Communications link failure”错误

目录 前言 第一种方法: 第二种方法 第三种方法(适用于项目和数据库在同一台服务器) 第四种方法 第五种方法(项目和数据库不在同一台服务器) 总结 前言 先给大家简述一下我的坑吧,(我用的是mysql,至于oracle有没有这样的问题,有心的小伙伴们可以测试一下哈), 在自己做个javaweb测试项目的时候,因为买的是云服务器,所以数据库连接的是用ip地址,用IDE开发好...

人工智能-计算机视觉实战之路(必备算法+深度学习+项目实战)

系列课程主要分为3大阶段:(1)首先掌握计算机视觉必备算法原理,结合Opencv进行学习与练手,通过实际视项目进行案例应用展示。(2)进军当下最火的深度学习进行视觉任务实战,掌握深度学习中必备算法原理与网络模型架构。(3)结合经典深度学习框架与实战项目进行实战,基于真实数据集展开业务分析与建模实战。整体风格通俗易懂,项目驱动学习与就业面试。 建议同学们按照下列顺序来进行学习:1.Python入门视频课程 2.Opencv计算机视觉实战(Python版) 3.深度学习框架-PyTorch实战/人工智能框架实战精讲:Keras项目 4.Python-深度学习-物体检测实战 5.后续实战课程按照自己喜好选择就可以

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

Python数据分析师-实战系列

系列课程主要包括Python数据分析必备工具包,数据分析案例实战,核心算法实战与企业级数据分析与建模解决方案实战,建议大家按照系列课程阶段顺序进行学习。所有数据集均为企业收集的真实数据集,整体风格以实战为导向,通俗讲解Python数据分析核心技巧与实战解决方案。

YOLOv3目标检测实战系列课程

《YOLOv3目标检测实战系列课程》旨在帮助大家掌握YOLOv3目标检测的训练、原理、源码与网络模型改进方法。 本课程的YOLOv3使用原作darknet(c语言编写),在Ubuntu系统上做项目演示。 本系列课程包括三门课: (1)《YOLOv3目标检测实战:训练自己的数据集》 包括:安装darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 (2)《YOLOv3目标检测:原理与源码解析》讲解YOLOv1、YOLOv2、YOLOv3的原理、程序流程并解析各层的源码。 (3)《YOLOv3目标检测:网络模型改进方法》讲解YOLOv3的改进方法,包括改进1:不显示指定类别目标的方法 (增加功能) ;改进2:合并BN层到卷积层 (加快推理速度) ; 改进3:使用GIoU指标和损失函数 (提高检测精度) ;改进4:tiny YOLOv3 (简化网络模型)并介绍 AlexeyAB/darknet项目。

2021考研数学张宇基础30讲.pdf

张宇:博士,全国著名考研数学辅导专家,教育部“国家精品课程建设骨干教师”,全国畅销书《张宇高等数学18讲》《张宇线性代数9讲》《张宇概率论与数理统计9讲》《张宇考研数学题源探析经典1000题》《张宇考

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

DirectX修复工具V4.0增强版

DirectX修复工具(DirectX Repair)是一款系统级工具软件,简便易用。本程序为绿色版,无需安装,可直接运行。 本程序的主要功能是检测当前系统的DirectX状态,如果发现异常则进行修复

期末考试评分标准的数学模型

大学期末考试与高中的考试存在很大的不同之处,大学的期末考试成绩是主要分为两个部分:平时成绩和期末考试成绩。平时成绩和期末考试成绩总分一般为一百分,然而平时成绩与期末考试成绩所占的比例不同会导致出现不同

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

c语言项目开发实例

十个c语言案例 (1)贪吃蛇 (2)五子棋游戏 (3)电话薄管理系统 (4)计算器 (5)万年历 (6)电子表 (7)客户端和服务器通信 (8)潜艇大战游戏 (9)鼠标器程序 (10)手机通讯录系统

相关热词 c# dbml文件 修改 c#遍历tree c# 能够控制单片机 c#对象写入数据库 c# 添加activex c#2005 json c# 数据库在云端 c# 字符串移位加密 c#禁用滚轮 c#实体类list去重复
立即提问