QTableWidget 不显示值
QTableWidget doesn't show values
我正在尝试使用 PyQt 将数据集插入到 QTableWidget 中。但是,当我使用 tableWidget.setItem()
时,我的 IDE 崩溃了。
usuarios = db.child("operacoes").get()
line = 0
for usuario in usuarios.each():
dados = list(usuario.val().values())
self.ui.tableWidget.setItem(line, 0, QTableWidgetItem(dados[0]))
self.ui.tableWidget.setItem(line, 1, QTableWidgetItem(dados[1]))
self.ui.tableWidget.setItem(line, 2, QTableWidgetItem(dados[2]))
self.ui.tableWidget.setItem(line, 3, QTableWidgetItem(dados[3]))
self.ui.tableWidget.setItem(line, 4, QTableWidgetItem(str(dados[4])))
self.ui.tableWidget.setItem(line, 5, QTableWidgetItem(str(dados[5])))
self.ui.tableWidget.setItem(line, 6, QTableWidgetItem(str(dados[6])))
line = line + 1
数据从 Firebase 检索并存储在向量中。我正在尝试使用我用来从 firebase 检索数据的相同循环来填充 table。但是,当我执行这段代码时,我的 QTableWidget 是空白的。
我的 dados
向量具有以下值:
dados[0] = "01/01/2000"
dados[1] = "JPY"
dados[2] = "teste"
dados[3] = "BRL"
dados[4] = 1.40
dados[5] = 14.00
dados[6] = 100
我的 table 使用 QtDesigner 是这样设计的:
我该如何解决这个问题?
按照 QTableWidget
的文档,在将 QTableWidgetItems
添加到单元格之前,您必须声明 QTableWidget
的大小(行和列)。这可以在创建 table 对象(在构造函数中)时完成,或者在 插入项目之前更改 table 的大小。
在您的情况下,您可能已经创建了一个大小为 1 行 x 7 列的 table,因此您必须在插入项目之前调整 table 的大小。
这可以通过添加
来实现
usuarios = db.child("operacoes").get()
line = 0
self.ui.tableWidget.setRowCount(len(list(usuarios.val().values())))
for usuario in usuarios.each():
dados = list(usuario.val().values())
self.ui.tableWidget.setItem(line, 0, QTableWidgetItem(dados[0]))
....
我正在尝试使用 PyQt 将数据集插入到 QTableWidget 中。但是,当我使用 tableWidget.setItem()
时,我的 IDE 崩溃了。
usuarios = db.child("operacoes").get()
line = 0
for usuario in usuarios.each():
dados = list(usuario.val().values())
self.ui.tableWidget.setItem(line, 0, QTableWidgetItem(dados[0]))
self.ui.tableWidget.setItem(line, 1, QTableWidgetItem(dados[1]))
self.ui.tableWidget.setItem(line, 2, QTableWidgetItem(dados[2]))
self.ui.tableWidget.setItem(line, 3, QTableWidgetItem(dados[3]))
self.ui.tableWidget.setItem(line, 4, QTableWidgetItem(str(dados[4])))
self.ui.tableWidget.setItem(line, 5, QTableWidgetItem(str(dados[5])))
self.ui.tableWidget.setItem(line, 6, QTableWidgetItem(str(dados[6])))
line = line + 1
数据从 Firebase 检索并存储在向量中。我正在尝试使用我用来从 firebase 检索数据的相同循环来填充 table。但是,当我执行这段代码时,我的 QTableWidget 是空白的。
我的 dados
向量具有以下值:
dados[0] = "01/01/2000"
dados[1] = "JPY"
dados[2] = "teste"
dados[3] = "BRL"
dados[4] = 1.40
dados[5] = 14.00
dados[6] = 100
我的 table 使用 QtDesigner 是这样设计的:
我该如何解决这个问题?
按照 QTableWidget
的文档,在将 QTableWidgetItems
添加到单元格之前,您必须声明 QTableWidget
的大小(行和列)。这可以在创建 table 对象(在构造函数中)时完成,或者在 插入项目之前更改 table 的大小。
在您的情况下,您可能已经创建了一个大小为 1 行 x 7 列的 table,因此您必须在插入项目之前调整 table 的大小。
这可以通过添加
usuarios = db.child("operacoes").get()
line = 0
self.ui.tableWidget.setRowCount(len(list(usuarios.val().values())))
for usuario in usuarios.each():
dados = list(usuario.val().values())
self.ui.tableWidget.setItem(line, 0, QTableWidgetItem(dados[0]))
....