Search code examples
pythonpyqtpyqt5qt-designerpyuic

Adding Functions to Buttons via Importing PyQt5 Ui


I have a PyQt5 Ui named guiNext.py and next.py which is refrencing the UI. How do I add function to the UI button? This is what I have and nothing happens when I run next.py and click on HELLO button.

guiNext.py:

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

# Form implementation generated from reading ui file 'guiNext_001.ui'
#
# Created by: PyQt5 UI code generator 5.6
#
# WARNING! All changes made in this file will be lost!

from PyQt5 import QtCore, QtGui, QtWidgets

class Ui_nextGui(object):
    def setupUi(self, nextGui):
        nextGui.setObjectName("nextGui")
        nextGui.resize(201, 111)
        nextGui.setMinimumSize(QtCore.QSize(201, 111))
        nextGui.setMaximumSize(QtCore.QSize(201, 111))
        self.centralwidget = QtWidgets.QWidget(nextGui)
        self.centralwidget.setObjectName("centralwidget")
        self.helloBtn = QtWidgets.QPushButton(self.centralwidget)
        self.helloBtn.setGeometry(QtCore.QRect(10, 10, 181, 91))
        self.helloBtn.setObjectName("helloBtn")
        nextGui.setCentralWidget(self.centralwidget)

        self.retranslateUi(nextGui)
        QtCore.QMetaObject.connectSlotsByName(nextGui)

    def retranslateUi(self, nextGui):
        _translate = QtCore.QCoreApplication.translate
        nextGui.setWindowTitle(_translate("nextGui", "MainWindow"))
        self.helloBtn.setText(_translate("nextGui", "HELLO"))

and here is main file next.py:

#!usr/bin/env python
#-*- coding: utf-8 -*-

from PyQt5 import QtCore, QtGui, QtWidgets
from guiNext import Ui_nextGui

class mainProgram(Ui_nextGui):
    def __init__(self, parent=None):
        Ui_nextGui.__init__(self)
        self.setupUi(nextGui)
        self.helloBtn.clicked.connect(self.hello)

    def hello(self):
        print ("HELLO")

if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    nextGui = QtWidgets.QMainWindow()
    ui = Ui_nextGui()
    ui.setupUi(nextGui)
    nextGui.show()
    sys.exit(app.exec_())

Solution

  • The structure of your program is not quite right. There are several ways to use the ui files created by Qt Designer. The multiple-inheritance approach is possibly the most intuitive. This is what your code should look like:

    from PyQt5 import QtCore, QtGui, QtWidgets
    from guiNext import Ui_nextGui
    
    class mainProgram(QtWidgets.QMainWindow, Ui_nextGui):
        def __init__(self, parent=None):
            super(mainProgram, self).__init__(parent)
            self.setupUi(self)
            self.helloBtn.clicked.connect(self.hello)
    
        def hello(self):
            print ("HELLO")
    
    if __name__ == "__main__":
    
        import sys
        app = QtWidgets.QApplication(sys.argv)
        nextGui = mainProgram()
        nextGui.show()
        sys.exit(app.exec_())