Search code examples
qtpyqtqtableviewqtguiqdialog

How to show a QDialog


I need to show a find dialog after pressing Ctrl+F in QWidget, which contains a QTableView. The find dialog will search in the first column of the table to find the matches.

I can show the QMessageBox after pressing Ctrl+F with the following code:

class Widget(QWidget):
    def __init__(self,md,parent=None):
        QWidget.__init__(self,parent)
        layout=QVBoxLayout(self)

        # initially construct the visible table
        tv = QTableView()
        # uncomment this if the last column shall cover the rest
        tv.horizontalHeader().setStretchLastSection(True)
        tv.show()

        # set black grid lines
        self.setStyleSheet("gridline-color: rgb(39, 42, 49)")

        # construct the Qt model belonging to the visible table
        model = NvmQtModel(md)
        tv.setModel(model)
        tv.resizeRowsToContents()
        tv.resizeColumnsToContents()

        # set the shortcut ctrl+F for find in menu
        shortcut = QShortcut(QKeySequence('Ctrl+f'), self)
        shortcut.activated.connect(self.handleFind)

        # delegate for decimal
        delegate = NvmDelegate()
        tv.setItemDelegate(delegate)
        self.setGeometry(200,200,600,600) # adjust this later
        layout.addWidget(tv)

        # set window title
        self.setWindowTitle("TITLE")

        # find function: search in the first column of the table
        def handleFind(self):
            reply = QMessageBox.question(
                self, 'Find', 'Find Dialog',
                QMessageBox.Yes | QMessageBox.No)
            if reply == QMessageBox.Yes:
                print('Yes')
            else:
                print('No')

Then I changed the QMessageBox to a QDialog, but now it does not work. I would appreciate if you could tell me where I am not doing it correctly:

class Widget(QWidget):
    def __init__(self,md,parent=None):
        QWidget.__init__(self,parent)
        layout=QVBoxLayout(self)

        # initially construct the visible table
        tv = QTableView()
        # uncomment this if the last column shall cover the rest
        tv.horizontalHeader().setStretchLastSection(True)
        tv.show()

        # set black grid lines
        self.setStyleSheet("gridline-color: rgb(39, 42, 49)")

        # construct the Qt model belonging to the visible table
        model = NvmQtModel(md)
        tv.setModel(model)
        tv.resizeRowsToContents()
        tv.resizeColumnsToContents()

        # set the shortcut ctrl+F for find in menu
        shortcut = QShortcut(QKeySequence('Ctrl+f'), self)
        shortcut.activated.connect(self.handleFind)

        # delegate for decimal
        delegate = NvmDelegate()
        tv.setItemDelegate(delegate)
        self.setGeometry(200,200,600,600) # adjust this later
        layout.addWidget(tv)

        # set window title
        self.setWindowTitle("TITLE")

    # find function: search in the first column of the table
    def handleFind(self):
        findDialog = QDialog()
        findLabel = QLabel("Find what", findDialog)
        findField = QLineEdit(findDialog)
        findButton = QPushButton("Find", findDialog)
        closeButton = QPushButton("Close", findDialog)
        findDialog.show()

Solution

  • If you want the Dialog be a modal Dialog, call findDialog.exec_():

    from PyQt4.QtGui import *
    
    def handleFind():
        findDialog = QDialog()
        #findDialog.setModal(True)
        findLabel = QLabel("Find what", findDialog)
        findField = QLineEdit(findDialog)
        findButton = QPushButton("Find", findDialog)
        closeButton = QPushButton("Close", findDialog)
        #findDialog.show()
        findDialog.exec_()
    
    
    app = QApplication([])
    
    b = QPushButton("click me")    
    b.clicked.connect(handleFind)
    b.show()
    
    app.exec_()