gpt4 book ai didi

python - 将对象列表从 pyqt5 传递到 qml 返回未定义

转载 作者:太空宇宙 更新时间:2023-11-04 04:56:41 24 4
gpt4 key购买 nike

我想将字典列表从 pyqt5 传递到 qml,其中该列表成为 ListView 元素的 model。以下代码是我目前所拥有的。

主要.py

class MainWindow(QQuickView):

def __init__(self, parent=None):
super().__init__(parent)
self.model = model.PersonModel()
self.rootContext().setContextProperty('PersonModel', self.model)
self.rootContext().setContextProperty('MainWindow', self)
self.setSource(QUrl('main.qml'))

@pyqtSlot()
def personsList(self):
print(self.model.persons) # this prints the list of objects perfectly fine
return(self.model.persons)
.
.
.

主.qml

ListView {
id: listExample
anchors.fill: parent
model: MainWindow.personsList()
delegate: PersonDelegate { }
highlight: highlightComponent
highlightMoveDuration: 0
Component.onCompleted: {
console.log(">>>", MainWindow.personsList()) // returns undefined, but why??
}
}

模型.py

from PyQt5.QtCore import QAbstractListModel, Qt, QModelIndex 

class PersonModel(QAbstractListModel):

NAME_ROLE = Qt.UserRole + 1
AGE_ROLE = Qt.UserRole + 2

def __init__(self, parent=None):
super().__init__(parent)
self.persons = [
{'name': 'jon', 'age': 20},
{'name': 'jane', 'age': 25},
{'name': 'pete', 'age': 25},
{'name': 'winson', 'age': 25},
{'name': 'ben', 'age': 25},
{'name': 'jiahao', 'age': 25}
]

self.currentIndex = 0

def data(self, index, role=Qt.DisplayRole):
row = index.row()
if role == PersonModel.NAME_ROLE:
return self.persons[row]["name"]
if role == PersonModel.AGE_ROLE:
return self.persons[row]["age"]

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

def roleNames(self):
return {
PersonModel.NAME_ROLE: b'name',
PersonModel.AGE_ROLE: b'age'
}

def updateIndex(self, int):
self.currentIndex = int
print("updating index from click", self.currentIndex)

def addPerson(self, name, age):
self.beginInsertRows(QModelIndex(), self.rowCount(), self.rowCount())
self.persons.append({'name': name, 'age': age})
self.endInsertRows()

def insertPerson(self, row, name, age):
self.beginInsertRows(QModelIndex(), row, row)
self.persons.insert(row, {'name': name, 'age': age})
self.endInsertRows()

def editPerson(self, row, name, age):
ix = self.index(row, 0)
self.persons[row] = {'name': name, 'age': age}
self.dataChanged.emit(ix, ix, self.roleNames())

def deletePerson(self, row):
self.beginRemoveColumns(QModelIndex(), row, row)
del self.persons[row]
self.endRemoveRows()

为什么qml中的人员列表返回undefined?

万一有人想知道,我正在尝试创建一个模型类,我可以通过传递任何字典列表来实例化它,并将此列表用作不同 ListView< 中的 model 属性 元素。在这个模型类中,我有 addinserteditdelete,我可以在所有实例中一致地使用它们,并且从而避免重复。

此外,我正在尝试将模型与 View 分开,以便数据流是一种方式,即 qml 通知 python 任何用户交互和 model 中的所有更改> 将在 python 上处理,每当 model 更改时,qml 将相应更改。

最佳答案

在 Qt 中有 Q_INVOKABLE 宏启用和注册该函数,以便它可以从 QML 使用,在 PyQt 中它的等价物是 pyqtSlot( ) 我们必须通过 result 参数告诉你它返回什么样的数据。

@pyqtSlot(result=list)
def personsList(self):
print(self.model.persons)
return self.model.persons

在您的 QML 代码中观察到的一个错误是您将对象列表而不是模型作为模型传递给 ListView:

import QtQuick 2.6

ListView {
id: listExample
anchors.fill: parent
model: PersonModel
delegate: Text{
text: name
}
highlightMoveDuration: 0
Component.onCompleted: {
console.log(">>>", MainWindow.personsList()) // returns undefined, but why??
var l = MainWindow.personsList();
for(var counter in l){
console.log(l[counter]['name'] + ": " + l[counter]['age'])
}
}
}

输出:

[{'name': 'jon', 'age': 20}, {'name': 'jane', 'age': 25}]
qml: >>> [[object Object],[object Object]]
[{'name': 'jon', 'age': 20}, {'name': 'jane', 'age': 25}]
qml: jon: 20
qml: jane: 25

关于python - 将对象列表从 pyqt5 传递到 qml 返回未定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46893080/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com