PyQt5:連接到點擊訊號的插槽不起作用
首先,对不起我的英语。我的母语是西班牙语。 所以,我正在做这个小项目来学习python。我正在学习如何使用 pyqt5 做 ui。这个应用程序很简单,它有三个输入、一个按钮和一个输出。 我在此应用程序中使用 mvc 软件模式,并且我的视图、模型和控制器位于单独的文件中。
问题: 在控制器类中,我将唯一的按钮连接到名为 (_calculate) 的插槽。当我运行应用程序并按下该按钮时,终端应该打印一条文本,以便我可以查看它是否正常工作。终端没有向我显示任何内容。 尝试不同类型的事情后,我发现如果我在视图类中执行相同的绑定,则会执行 _calculate 。我做了一个关于使用 pyqt5 的计算器的教程。本教程中的计算器使用 mvc 工作得很好,所以我用它来查明我是否忘记或错过了某些内容,但没有出现任何明显的情况。
我的控制器类
class controller: def __init__(self, view): self._view = view self._connectsignals() def _connectsignals(self): self._view.button.clicked.connect(self._calculate) def _calculate(self): print('trying to calculate')
我的视图类
from pyqt5.qtwidgets import qmainwindow from pyqt5.qtwidgets import qvboxlayout from pyqt5.qtwidgets import qhboxlayout from pyqt5.qtwidgets import qwidget from pyqt5.qtwidgets import qlabel from pyqt5.qtwidgets import qlineedit from pyqt5.qtwidgets import qspaceritem from pyqt5.qtwidgets import qsizepolicy from pyqt5.qtwidgets import qpushbutton from pyqt5.qtwidgets import textedit from pyqt5.qtgui import qpixmap from pyqt5.qtcore import qt from toolcontroller import controller class userinterface(qmainwindow): def __init__(self): super().__init__() self.setwindowtitle('bdo tool') self.setfixedsize(450, 300) self._centralwidget = qwidget(self) self.setcentralwidget(self._centralwidget) self._createwindowskeleton() def _createwindowskeleton(self): # vertical container who contains all the program widget self._generallayout = qvboxlayout() self._centralwidget.setlayout(self._generallayout) self._generallayout.setalignment(qt.aligncenter) self._generallayout.addlayout(self._createfirstrow()) self._generallayout.addlayout(self._createbutton()) self._generallayout.addwidget(self._createareatext()) def _createfirstrow(self): hlayout = qhboxlayout() spacer = qspaceritem(20, 20, hpolicy=qsizepolicy.expanding) self._inputboxes = { self.input_base_fail: (qpixmap(self.img_base_fails), qlineedit()), self.input_target_fail: (qpixmap(self.img_target_fail), qlineedit()), self.input_stack_amount: (qpixmap(self.img_stack_amount), qlineedit()), } keys = list(self._inputboxes.keys()) for key, value in self._inputboxes.items(): pixmap, editline = value label = qlabel() label.setpixmap(pixmap) editline.setfixedwidth(40) editline.setalignment(qt.alignright) hlayout.addwidget(label) hlayout.addwidget(editline) if key != keys[-1]: hlayout.addspaceritem(spacer) return hlayout def _createbutton(self): self.button = qpushbutton('calculate') spacer = qspaceritem(20, 20, hpolicy=qsizepolicy.expanding) hlayout = qhboxlayout() hlayout.addspaceritem(spacer) hlayout.addwidget(self.button) hlayout.addspaceritem(spacer) return hlayout def _createareatext(self): self._infodisplay = qtextedit() self._infodisplay.setenabled(false) return self._infodisplay input_base_fail = 1 input_target_fail = 2 input_stack_amount = 3 img_base_fails = 'img\\user25x25.png' img_target_fail = 'img\\target25x25.png' img_stack_amount = 'img\\stack25x25.png'
我的主要内容
import sys from PyQt5.QtWidgets import QApplication from ToolView import UserInterface from ToolController import Controller def main(): app = QApplication(sys.argv) view = UserInterface() view.show() Controller(view=view) sys.exit(app.exec()) if __name__ == '__main__': main()
正确答案
问题是您没有为控制器实例创建持久对象,因此该实例随后会立即被垃圾收集,因为它没有在其他任何地方引用。
只要存在对实例的引用,它就会按预期工作。
在这种情况下,一个局部变量就足够了,因为 app.exec()
将阻止 main
内的进一步处理,确保实例将存在直到它存在。
def main(): app = QApplication(sys.argv) view = UserInterface() view.show() controller = Controller(view=view) sys.exit(app.exec())
尽管如此,让我告诉您,虽然从概念上来说使用 mvc 通常是一个好主意,但您应该谨慎使用它,不要“夸大”模式,并且只有在它确实有助于开发时才使用它。
我想指出其中一个mvc 的缺点:
我知道您的示例是一个简单且概念性的示例,但就其用途而言,它确实是一个过于复杂的示例。例如:
- 您似乎没有使用模型,或者至少您似乎不需要完整的 mvc 模式来做到这一点(只要有实际优势,就应该选择 mvc)这样做,而不是“因为你应该使用它”);
- 使用 mvc 模式并不一定意味着您必须使用 3 个类(和 3 个单独的文件),这也可能会降低代码的可导航性; mvc 主要是关于程序逻辑中这三个元素的划分方式:qt(大多数提供 ui 元素的框架)已经对此有所帮助,因为它提供了除了显示自身之外几乎不执行任何操作的 ui 元素,以及允许交互的其他元素与它们(文件访问、网络接口和实际模型);
- 过度使用函数来创建 ui 通常是一个坏主意,因为它使事情变得比实际情况复杂得多,最重要的是从可读性的角度来看:虽然使用单独的函数可能有助于为了保持代码“更整洁”,还创建了函数以实现可重用性,并且在
userinterface
类中,有 4 个函数肯定只会使用一次。
以上是PyQt5:連接到點擊訊號的插槽不起作用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

Python更易學且易用,C 則更強大但複雜。 1.Python語法簡潔,適合初學者,動態類型和自動內存管理使其易用,但可能導致運行時錯誤。 2.C 提供低級控制和高級特性,適合高性能應用,但學習門檻高,需手動管理內存和類型安全。

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python在開發效率上優於C ,但C 在執行性能上更高。 1.Python的簡潔語法和豐富庫提高開發效率。 2.C 的編譯型特性和硬件控制提升執行性能。選擇時需根據項目需求權衡開發速度與執行效率。

Python在自動化、腳本編寫和任務管理中表現出色。 1)自動化:通過標準庫如os、shutil實現文件備份。 2)腳本編寫:使用psutil庫監控系統資源。 3)任務管理:利用schedule庫調度任務。 Python的易用性和豐富庫支持使其在這些領域中成為首選工具。

pythonlistsarepartofthestAndArdLibrary,herilearRaysarenot.listsarebuilt-In,多功能,和Rused ForStoringCollections,而EasaraySaraySaraySaraysaraySaraySaraysaraySaraysarrayModuleandleandleandlesscommonlyusedDduetolimitedFunctionalityFunctionalityFunctionality。

每天學習Python兩個小時是否足夠?這取決於你的目標和學習方法。 1)制定清晰的學習計劃,2)選擇合適的學習資源和方法,3)動手實踐和復習鞏固,可以在這段時間內逐步掌握Python的基本知識和高級功能。
