qtableview 从查询中添加行并在 python 中编辑它们

qtableview add rows from a query and edit them in python

我使用 Python 2.7、MariaDB 和 Qt4。我有一个 table,我想在其中插入查询中的行。我试过 self.model = QtSql.QSqlQueryModel() 但我发现这只是只读的。然后我转移到别的地方。

我的 Model() class 看起来像这样:

class Model(QAbstractTableModel):
    def __init__(self, parent=None, *args):
        QAbstractTableModel.__init__(self, parent, *args)
        query = QtSql.QSqlQuery()
        query.prepare("SELECT denumire,pret_in,pret_out,cantitate,unitate_masura,tax FROM produse WHERE denumire='"+str(self.run_denumire())+"';")
        query.exec_()
        while(query.next()):
            nume_produs = str(query.value(0).toString())
            pret_in = str(query.value(1).toString())
            pret_out = str(query.value(2).toString())
            cantitate = str(query.value(3).toString())
            unitate_masura = str(query.value(4).toString())
            tax_tva = str(query.value(5).toString())
        self.items = [nume_produs,pret_in,pret_out,cantitate,unitate_masura]

    def rowCount(self, parent=QModelIndex()):
        return 1

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

    def data(self, index, role):
        if not index.isValid(): return QVariant()
        elif role != Qt.DisplayRole:
            return QVariant()

        column=index.column()
        if column<len(self.items):
            return QVariant(self.items[column])
        else:
            return QVariant()

    def flags(self, index):
        return Qt.ItemIsEnabled | Qt.ItemIsSelectable | Qt.ItemIsEditable

我是 Qt 新手,我不知道如何逐行插入以显示在 table 上。你在这里看到的是我在 Whosebug 上找到的代码,我用查询修改了它。我需要一些帮助。

我的主要代码是这样的:

import time,os.path, os,module
from PyQt4 import QtGui, uic,QtSql,QtCore
from PyQt4.QtCore import *
from PyQt4.QtGui import *

class dialog_receptie(QtGui.QDialog):
    def __init__(self):
        QtGui.QDialog.__init__(self)
        file_path = os.path.abspath("ui/receptie.ui")
        uic.loadUi(file_path, self)
        self.move(QtGui.QApplication.desktop().screen().rect().center() - self.rect().center())

我的 ui 文件是:file 该文件由 Qt Designer 制作。 谢谢。

更新 1:

我在 class dialog_receptie 中插入了一个函数。它看起来像这样:

def show_lista_receptie(self):
    # self.model = QtSql.QSqlQueryModel()
    # self.model.setQuery("SELECT den_produs,concat(pret_in,' Lei'),concat(pret_out,' Lei'),val_tva,cantitate,um FROM receptie_temp;")
    self.model = QtSql.QSqlTableModel()
    self.model.setTable("produse")
    self.model.setQuery("SELECT * FROM receptie_temp;")
    self.model.setHeaderData(1, QtCore.Qt.Horizontal, self.tr("Produs         "))
    self.model.setHeaderData(4, QtCore.Qt.Horizontal, self.tr("Pret cumparare "))
    self.model.setHeaderData(5, QtCore.Qt.Horizontal, self.tr("Pret vanzare   "))
    self.model.setHeaderData(6, QtCore.Qt.Horizontal, self.tr("TVA Produs     "))
    self.model.setHeaderData(7, QtCore.Qt.Horizontal, self.tr("Cantitate      "))
    self.model.setHeaderData(11, QtCore.Qt.Horizontal, self.tr("UM             "))
    self.produse_view.setModel(self.model)
    self.produse_view.hideColumn(0)  # hide id column
    self.produse_view.hideColumn(2)
    self.produse_view.hideColumn(3)
    self.produse_view.hideColumn(8)
    self.produse_view.hideColumn(9)
    self.produse_view.hideColumn(10)
    self.produse_view.hideColumn(12)

如果我使用这一行 self.model.setQuery("SELECT * FROM receptie_temp;") 我会收到一条错误消息:

File "E:\onedrive\Documents\optimpos\module\receptie.py", line 64, in show_lista_receptie
    self.model.setQuery("SELECT * FROM receptie_temp;")
TypeError: setQuery(self, QSqlQuery): argument 1 has unexpected type 'str'

如何在不使用数组的情况下从 receptie_temp table 查询数据? table 中的编辑值如何更新为 sql table?

谢谢。

我建议使用 QSqlTableModel class:

The QSqlTableModel class provides an editable data model for a single database table.

你的情况:

import os
import sys

from PyQt4 import QtGui, uic, QtSql
from PyQt4.QtGui import *


class dialog_receptie(QtGui.QDialog):
    def __init__(self):
        QtGui.QDialog.__init__(self)
        file_path = os.path.abspath("ui/receptie.ui")
        uic.loadUi(file_path, self)
        # self.move(QtGui.QApplication.desktop().screen().rect().center() - self.rect().center())
        db = QtSql.QSqlDatabase.addDatabase('QMYSQL')
        db.setHostName(HOSTNAME);
        db.setDatabaseName(DATABASE);
        db.setUserName(USER);
        db.setPassword(PASSWORD)
        self.model = QtSql.QSqlTableModel()
        self.model.setTable("produse")

        self.produse_view.setModel(self.model)
        self.produse_view.hideColumn(0) # hide id column
        self.addData(["a", "b", "c", "d", "e", "f"])

    def addData(self, data):

        rec = self.model.record()

        for i in range(6):
            rec.setValue(rec.field(i+1).name(), data[i])
        self.model.insertRecord(-1, rec)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    w = dialog_receptie()
    w.show()
    sys.exit(app.exec_())