[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问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
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 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)

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如何弹出多个界面心事多组不同的数据

我这里有多组数据需要展示,展示的界面是在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() ```

用PyQt5,通过url获取页面,然后把整个页面截屏

import sys from PyQt5.QtCore import QUrl from PyQt5.QtWidgets import QApplication from PyQt5.QtWebEngineWidgets import QWebEnginePage, QWebEngineView app = QApplication(sys.argv) browser = QWebEngineView() browser.load(QUrl("http://news.baidu.com/?tn=news")) browser.show() app.exec_() r = WebRender(url) html = r.frame.toHtml() page = etree.HTML(html.encode('utf-8')) 这个页面整个截屏

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关于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 请教下是什么原因造成上述两个问题。

给以前写的一个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_()) ```

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

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

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_()) ``` 没有播放,不知道问题在哪儿? ```

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这么基础的功能上反而不成熟。

怎么防止qt窗口卡死??

``` # -*- coding:utf-8 -*- import sys import time from PyQt5.QtWidgets import QApplication,QWidget,QLabel,QPushButton,QVBoxLayout,QHBoxLayout,QComboBox,QRadioButton,QLineEdit from PyQt5.QtGui import QMovie,QPixmap from PyQt5.QtCore import Qt,QBuffer,QByteArray,QIODevice,pyqtSignal,QThread,QEventLoop,QSize,QTimer class win(QWidget): def __init__(self,parent=None): super(win,self).__init__(parent) self.resize(500,500) self.child = t() self.child.hello.connect(self.hi) self.child.start() def hi(self,msg): print(111) class t(QThread): hello = pyqtSignal(str) def __init__(self,parent=None): super(t,self).__init__(parent) def __del__(self): self.wait() def run(self): app.processEvents() self.loop = QEventLoop() self.lbl = QLabel() self.lbl.resize(300,300) self.lbl.show() self.t1 = t1() self.t1.hell.connect(self.qu) self.t1.start() self.loop.exec_() def qu(self,msg): if msg: self.lbl.quit() self.loop.quit() class t1(QThread): hell = pyqtSignal(str) def __init__(self,parent=None): super(t1,self).__init__(parent) def run(self): time.sleep(20) self.hell.emit("111") if __name__=="__main__": app = QApplication(sys.argv) win=win() win.show() sys.exit(app.exec_()) ``` 是QEventLoop用错了吗???

为什么我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里就行得通,有哪位大神能解答一下吗?

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_()) ```

用pyqt5 编写一个可实现账号密码登录的界面

用pyqt5 编写一个可实现账号密码登录的界面,点击登录可跳转主界面的程序代码。刚学,弄了好几天都没头绪,求大神帮帮忙。

用matplotlib生成好的图表怎么用pyqt5显示在界面上?

我已经用python3写好了调用matplotlib生成的数据图表,现在想做一个界面,在界面里的某一个位置显示这张图,在网上看了很多matplotlib跟pyqt5关联的例子,自己尝试都没有显示成功,求大神指点

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

我说我不会算法,阿里把我挂了。

不说了,字节跳动也反手把我挂了。

抖音上很火的时钟效果

反正,我的抖音没人看,别人都有几十万个赞什么的。 发到CSDN上来,大家交流下~ 主要用到原生态的 JS+CSS3。 具体不解释了,看注释: &lt;!DOCTYPE html&gt; &lt;html lang="en"&gt; &lt;head&gt; &lt;meta charset="UTF-8"&gt; &lt;title&gt;Title&lt;/tit...

记录下入职中软一个月(外包华为)

我在年前从上一家公司离职,没想到过年期间疫情爆发,我也被困在家里,在家呆着的日子让人很焦躁,于是我疯狂的投简历,看面试题,希望可以进大公司去看看。 我也有幸面试了我觉得还挺大的公司的(虽然不是bat之类的大厂,但是作为一名二本计算机专业刚毕业的大学生bat那些大厂我连投简历的勇气都没有),最后选择了中软,我知道这是一家外包公司,待遇各方面甚至不如我的上一家公司,但是对我而言这可是外包华为,能...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

手机经常收到"回复TD退订",回还是不回?今天总算是弄清楚了

自从有了微信和QQ,手机短信几乎很少再用了,但是我们手机里面还是经常会收到"回复TD退订"的消息,那到底要不要回复呢?今天就来告诉大家! 信息内容可能包括 推销信息 品牌活动日的时候,会根据你的用户浏览信息,或者购买记录,后续发送一些降价消息。 但是笔者想说我是缺那10块钱的人嘛,我缺的是1000块。 垃圾信息 虽然我们已经不经常用短信功能,但是还是有不少...

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试官问我:如何加载100M的图片却不撑爆内存

还记得当年面试一个面试官问我怎么加载巨图才能不撑爆内存,我没回答上来,他说分片显示,我寻思特么分片能减少内存使用??现在可以打他脸了! 内容扩展 1.图片的三级缓存中,图片加载到内存中,如果内存快爆了,会发生什么?怎么处理? 2.内存中如果加载一张 500*500 的 png 高清图片.应该是占用多少的内存? 3.Bitmap 如何处理大图,如一张 30M 的大图,如何预防 OOM? A...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

又出事了?网站被攻击了?高中生?

北京时间2020年3月27日9点整,如往常一样来到公司,带开电脑,正准备打开Github网站看一会源代码,再开始手头的工作。哟吼,一直打不开,一直出现如下页面: 我想很多网友也尝到了甜头,各大技术群炸开了锅,据网友反馈有攻击者正在发起大规模的中间人挟持,京东和Github等网站等网站都受到了影响。 什么是中间中间人挟持呢? 简而言之,就是攻击者在数据网络传输的过程中,截获传输过程中的数据并篡改...

无代码时代来临,程序员如何保住饭碗?

编程语言层出不穷,从最初的机器语言到如今2500种以上的高级语言,程序员们大呼“学到头秃”。程序员一边面临编程语言不断推陈出新,一边面临由于许多代码已存在,程序员编写新应用程序时存在重复“搬砖”的现象。 无代码/低代码编程应运而生。无代码/低代码是一种创建应用的方法,它可以让开发者使用最少的编码知识来快速开发应用程序。开发者通过图形界面中,可视化建模来组装和配置应用程序。这样一来,开发者直...

培训班出来的人后来都怎么样了?(二)

接着上回说,培训班学习生涯结束了。后面每天就是无休止的背面试题,不是没有头脑的背,培训公司还是有方法的,现在回想当时背的面试题好像都用上了,也被问到了。回头找找面试题,当时都是打印下来天天看,天天背。 不理解呢也要背,面试造飞机,上班拧螺丝。班里的同学开始四处投简历面试了,很快就有面试成功的,刚开始一个,然后越来越多。不知道是什么原因,尝到胜利果实的童鞋,不满足于自己通过的公司,嫌薪水要少了,选择...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

6年开发经验女程序员,面试京东Java岗要求薪资28K

写在开头: 上周面试了一位女程序员,上午10::30来我们部门面试,2B哥接待了她.来看看她的简历: 个人简历 个人技能: ● 熟悉spring mvc 、spring、mybatis 等框架 ● 熟悉 redis 、rocketmq、dubbo、zookeeper、netty 、nginx、tomcat、mysql。 ● 阅读过juc 中的线程池、锁的源...

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

工作八年,月薪60K,裸辞两个月,投简历投到怀疑人生!

近日,有网友在某职场社交平台吐槽,自己裸辞两个月了,但是找工作却让自己的心态都要崩溃了,全部无果,不是已查看无回音,就是已查看不符合。 “工作八年,两年一跳,裸辞两个月了,之前月薪60K,最近找工作找的心态崩了!所有招聘工具都用了,全部无果,不是已查看无回音,就是已查看不符合。进头条,滴滴之类的大厂很难吗???!!!投简历投的开始怀疑人生了!希望 可以收到大厂offer” 先来看看网...

推荐9个能让你看一天的网站

分享的这9个保证另你意外的网站,每个都非常实用!非常干货!毫不客气的说,这些网站最少值10万块钱。 利用好这些网站,会让你各方面的技能都得到成长,不说让你走上人生巅峰,但对比现在的你,在眼界、学识、技能方面都有质的飞跃。 一、AIRPANO 传送门:https://www.airpano.com/360photo_list.php 这是一个可以躺在家里,就能环游世界的神奇网站。 世界那么大,绝大多...

大牛都会用的IDEA调试技巧!!!

导读 前天面试了一个985高校的实习生,问了他平时用什么开发工具,他想也没想的说IDEA,于是我抛砖引玉的问了一下IDEA的调试用过吧,你说说怎么设置断点...

都前后端分离了,咱就别做页面跳转了!统统 JSON 交互

文章目录1. 无状态登录1.1 什么是有状态1.2 什么是无状态1.3 如何实现无状态1.4 各自优缺点2. 登录交互2.1 前后端分离的数据交互2.2 登录成功2.3 登录失败3. 未认证处理方案4. 注销登录 这是本系列的第四篇,有小伙伴找不到之前文章,松哥给大家列一个索引出来: 挖一个大坑,Spring Security 开搞! 松哥手把手带你入门 Spring Security,别再问密...

月薪22K程序员,打卡迟到10次,收到工资短信一脸懵逼

每家公司为了保证公司员工每天的工作时间,一般都会采用上下班打卡的工作制度,这其实是一个很常见的是,本身也没有什么问题的。正所谓无规矩不成方圆,公司肯定是有公司的规矩,虽然每个员工都很不喜欢这些规矩来束缚我们,但是公司也只是为了能更好的管理员工。但是一家公司如果一成不变的使用打卡制度,而不会去变通管理,也真不一定是好事。 打卡制度特别对于销售部门来说,不但会让公司发展不起来,还很容易丢失员工。但如...

97年世界黑客编程大赛冠军作品(大小仅为16KB),惊艳世界的编程巨作

这是世界编程大赛第一名作品(97年Mekka ’97 4K Intro比赛)汇编语言所写。 整个文件只有4095个字节, 大小仅仅为16KB! 不仅实现了3D动画的效果!还有一段震撼人心的背景音乐!!! 内容无法以言语形容,实在太强大! 下面是代码,具体操作看最后! @echo off more +1 %~s0|debug e100 33 f6 bf 0 20 b5 10 f3 a5...

不要再到处使用 === 了

我们知道现在的开发人员都使用 === 来代替 ==,为什么呢?我在网上看到的大多数教程都认为,要预测 JavaScript 强制转换是如何工作这太复杂了,因此建议总是使用===。这些都...

什么是a站、b站、c站、d站、e站、f站、g站、h站、i站、j站、k站、l站、m站、n站?00后的世界我不懂!

A站 AcFun弹幕视频网,简称“A站”,成立于2007年6月,取意于Anime Comic Fun,是中国大陆第一家弹幕视频网站。A站以视频为载体,逐步发展出基于原生内容二次创作的完整生态,拥有高质量互动弹幕,是中国弹幕文化的发源地;拥有大量超粘性的用户群体,产生输出了金坷垃、鬼畜全明星、我的滑板鞋、小苹果等大量网络流行文化,也是中国二次元文化的发源地。 B站 全称“哔哩哔哩(bilibili...

十个摸鱼,哦,不对,是炫酷(可以玩一整天)的网站!!!

文章目录前言正文**1、Kaspersky Cyberthreat real-time map****2、Finding Home****3、Silk – Interactive Generative Art****4、Liquid Particles 3D****5、WINDOWS93****6、Staggering Beauty****7、Ostagram图片生成器网址****8、全历史网址*...

我真的错了,我被跳槽后的高薪冲昏了头脑...

国内疫情已接近尾声,疫情对生活各个方面造成的影响,就是一场真实的“蝴蝶效应”。“全球最大安全套制造商因疫情停产,已造成一亿个安全套缺口”“口罩印钞机,月入千万的暴富神话”“百程旅行...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

​能让德国人放弃现金支付​,也没谁了

在新冠疫情中,德国人越来越多地选择在超市,加油站或其他商店付款时使用非接触式付款方式。德国信贷协会Deutschen Kreditwirtschaft (DK) 的一位发言人告诉德国新...

相关热词 c# 局部 截图 页面 c#实现简单的文件管理器 c# where c# 取文件夹路径 c# 对比 当天 c# fir 滤波器 c# 和站 队列 c# txt 去空格 c#移除其他类事件 c# 自动截屏
立即提问