TableView重新实现QAbstractTableMod后表中没有数据显示

2024-09-30 16:29:25 发布

您现在位置:Python中文网/ 问答频道 /正文

我无法在QML表视图中显示数据。我已经定义了两个数组-标题和行,我想在TableView上显示它们,但到目前为止还没有成功。下面是最小的可复制的例子。你知道吗

你知道吗引擎.py你知道吗

import os
import sys
from PySide2 import QtCore, QtGui, QtSql, QtQml
from Table import TbModel
from PySide2.QtWidgets import QApplication
if __name__ == "__main__":
    current_dir = os.path.dirname(os.path.realpath(__file__))
    app = QApplication(sys.argv)
    QtQml.qmlRegisterType(TbModel, "TbModel", 1, 0, "TbModel")
    engine = QtQml.QQmlApplicationEngine()
    qml_path = os.path.join( "main.qml")
    engine.load(QtCore.QUrl.fromLocalFile(qml_path))
    if not engine.rootObjects():
        sys.exit(-1)
    sys.exit(app.exec_())

你知道吗主.qml你知道吗

import QtQuick 2.13
import QtQuick.Window 2.2
import QtQuick.Controls 2.5
import QtQuick.Controls 1.4
import QtQuick.Controls 2.13
import TbModel 1.0

ApplicationWindow {
    visible: true
    id: window
    width: Screen.width
    height: Screen.height
    Grid {

    width: 300
    height: 100
    visible: true
    spacing: 200
    TableView
    {
        id: idtable
        model: TbModel { }
    TableViewColumn {
        role: "sci" 
        title: "sci"
    }
    TableViewColumn {
        role: "year"
        title: "year"
    }
    TableViewColumn {
        role: "cont"
        title: "cont"
    }

        // Component.onCompleted: {

        //     var roles = model.roleNameArray()
        //                 for (var i = 0; i < model.columnCount(); i++)
        //     {
        //         var column = addColumn( Qt.createQmlObject(
        //             "import QtQuick.Controls 1.1; TableViewColumn {}",
        //             this) )
        //         column.role=roles[i]
        //         column.title=roles[i]

        //     }
        // }
    }

}
}

你知道吗表.py你知道吗

from PySide2.QtCore import QAbstractTableModel, QModelIndex, QObject, Qt
from PySide2 import QtCore

class TbModel(QAbstractTableModel):
    def __init__(self, parent: QObject = None) -> None:
        super().__init__(parent)
        self.headers = ["sci", "year", "cont"]
        self.rows =    [("Newton", "1643-01-04", "Classical mechanics"),
           ("Einstein", "1879-03-14", "Relativity"),
           ("Darwin", "1809-02-12", "Evolution")]

    def rowCount(self, parent=QModelIndex()):
        return len(self.rows)

    def columnCount(self, parent=QModelIndex()):
        return len(self.headers)

    def data(self, index, role):
        if role != Qt.DisplayRole:
            return None
        return self.rows[index.row()][index.column()]

    def headerData(self, section, orientation, role) :
        if role != Qt.DisplayRole:
            return None

        if section < 0 or section >= len(self.headers):
            return None

        return self.headers[section]

    def roleNames(self):
        roles = {
            Qt.UserRole + 1 : 'sci',
            Qt.UserRole + 2 : 'year',
            Qt.UserRole + 3 : 'cont'
        }
        return roles


    @QtCore.Slot(result="QVariantList")
    def roleNameArray(self):
        names = []
        names=self.headers

        return names

我可以在TableView中选择行,但看不到数据。感谢您的帮助。你知道吗


Tags: pathfromimportselfnonereturnifdef
1条回答
网友
1楼 · 发布于 2024-09-30 16:29:25

您的代码有2个错误:

    >p>在C++ +{}方法中返回一个^ {< CD2>},所以在Python中,必须返回一个字典,该字典的键是整数,值必须是^ {< CD3>}或^ {CD4>},但在您的情况下,该值是一个字符串。

  • data方法必须提供视图所需的信息,在这种情况下,它们是与“sci”、“year”和“cont”相关联的角色,这些角色的值是Qt.UserRole + 1Qt.UserRole + 2Qt.UserRole + 3,它们与Qt.DisplayRole不同,但是在您的逻辑中,Qt.DisplayRole以外的任何值都不会与上述内容相矛盾。

  • QML提供了几个表视图:QtQuick.Controls 1.xQtQuick。在您的示例中,您使用的第一个模型不需要QAbstractTableModel,而只需要QAbstractListModel,因为视图使用的QModelIndex的列值始终为1。

  • 考虑到上述情况,您可能会遇到问题,因为QML提供了几个属于不同包的同名项,为了解决这个问题,使用了名称空间。

综上所述,解决方案是:

from PySide2.QtCore import QAbstractListModel, QModelIndex, QObject, Qt, Slot


class TbModel(QAbstractListModel):
    def __init__(self, parent: QObject = None) -> None:
        super().__init__(parent)
        self.headers = ["sci", "year", "cont"]
        self.rows = [
            ("Newton", "1643-01-04", "Classical mechanics"),
            ("Einstein", "1879-03-14", "Relativity"),
            ("Darwin", "1809-02-12", "Evolution"),
        ]

    def rowCount(self, parent=QModelIndex()):
        return len(self.rows)

    def data(self, index, role=Qt.DisplayRole):
        row = index.row()
        if 0 <= row < self.rowCount():
            if role in self.roleNames():
                name_role = self.roleNames()[role].decode()
                col = self.headers.index(name_role)
                return self.rows[row][col]

    def headerData(self, section, orientation, role):
        if role == Qt.DisplayRole and 0 <= section < len(self.headers):
            return self.headers[section]

    def roleNames(self):
        roles = {}
        for i, header in enumerate(self.headers):
            roles[Qt.UserRole + i + 1] = header.encode()
        return roles

    @Slot(result="QVariantList")
    def roleNameArray(self):
        return self.headers
import QtQuick 2.13
import QtQuick.Window 2.13
import QtQuick.Controls 1.4 as QQC1

import TbModel 1.0

QQC1.ApplicationWindow {
    id: window
    visible: true
    width: Screen.width
    height: Screen.height

    QQC1.TableView
    {
        id: idtable
        width: 600
        height: 300
        model: TbModel{ }
        QQC1.TableViewColumn {
            role: "sci" 
            title: "sci"
        }
        QQC1.TableViewColumn {
            role: "year"
            title: "year"
        }
        QQC1.TableViewColumn {
            role: "cont"
            title: "cont"
        }
    }
}

输出:

enter image description here

相关问题 更多 >