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

时间:2017-05-24 18:19:47

标签: python python-2.7 pyqt pyqt4 qabstracttablemodel

我使用Python 2.7,MariaDB和Qt4。我有一个表,我想从查询中插入行。我试过self.model = QtSql.QSqlQueryModel(),但我发现这只是只读的。然后我转向别的东西。

我的Model()课程如下:

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的新手,我不知道如何逐个插入行以显示在桌面上。你在这里看到的是我在stackoverflow上找到的代码,我用查询修改了它。我需要一些帮助。

我的主要代码是这样的:

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表中查询数据?如何将表中编辑的值更新为sql表?

谢谢。

1 个答案:

答案 0 :(得分:0)

我建议使用QSqlTableModel类:

  

QSqlTableModel 类为单个数据提供可编辑的数据模型   数据库表。

在你的情况下:

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_())

enter image description here