在QAbstractTableModel tableView中具有Enter作为key_down的行为

时间:2019-09-24 23:02:00

标签: python pyqt pyqt5

我正在PyQt5和Qt Designer中使用QAbstractTableModel创建数据表。我需要一点帮助,以找到一种简单的方法来使“ Enter” keyPressEvent在表中向下移动,就好像按下了Key_Down按钮一样。以下代码捕获Enter键按下事件。如何使其移动光标?

我已经搜索了论坛并用谷歌搜索了此问题,但还没有找到解决方案。我尝试创建一个自定义事件以将其传递给“ ev”,但这没有用。

def keyPressEvent(self, ev):        
    if ev.key() in (QtCore.Qt.Key_Return, QtCore.Qt.Key_Enter):
        print("Enter key pressed")

1 个答案:

答案 0 :(得分:1)

您必须使用QModelIndex方法使用新的moveCursor(),并使用setCurrentIndex()的{​​{1}}方法来设置新的选择。

selectionModel()

如果您使用的是Qt Designer,则有两种可能的实现方式:

  1. 升级QTableView以便在Qt Designer中使用。

  2. 使用eventFilter实施逻辑。

在这种情况下,我将展示如何实现第二种方法:

from PyQt5 import QtCore, QtGui, QtWidgets


class TableView(QtWidgets.QTableView):
    def keyPressEvent(self, event):
        if event.key() in (QtCore.Qt.Key_Return, QtCore.Qt.Key_Enter):
            index = self.moveCursor(
                QtWidgets.QAbstractItemView.MoveDown, QtCore.Qt.NoModifier
            )
            command = self.selectionCommand(index, event)
            self.selectionModel().setCurrentIndex(index, command)
        else:
            super(TableView, self).keyPressEvent(event)


if __name__ == "__main__":
    import sys

    app = QtWidgets.QApplication(sys.argv)

    model = QtGui.QStandardItemModel(10, 4)
    w = TableView()
    w.setModel(model)
    w.show()

    sys.exit(app.exec_())

然后在QTableView中进行设置:

class EventFilter(QtCore.QObject):
    def __init__(self, view):
        super(EventFilter, self).__init__(view)
        if not isinstance(view, QtWidgets.QAbstractItemView):
            raise TypeError("{} must be a QAbstractItemView".format(view))
        self._view = view
        self._view.installEventFilter(self)

    def eventFilter(self, obj, event):
        if obj is self._view and event.type() == QtCore.QEvent.KeyPress:
            if event.key() in (QtCore.Qt.Key_Return, QtCore.Qt.Key_Enter):
                index = self._view.moveCursor(
                    QtWidgets.QAbstractItemView.MoveDown, QtCore.Qt.NoModifier
                )
                command = self._view.selectionCommand(index, event)
                self._view.selectionModel().setCurrentIndex(index, command)
        return super(EventFilter, self).eventFilter(obj, event)