1

SQLiteデータベースからQTableViewにいくつかの簡単な情報を表示しようとしています。私はSOからの1つの答えに従いました、そしてそれ自体のために、それは働いています。同じコードをGUI(QTableViewオブジェクトを含む単純なメインウィンドウ)に実装しようとすると、何も表示されません。コードは次のとおりです。

from PyQt4 import QtCore, QtGui
from gui import Ui_MainWindow
from dialog import Ui_Dialog
from PyQt4.QtSql import QSqlQueryModel,QSqlDatabase,QSqlQuery

import sys

class Glavni(QtGui.QMainWindow):
    def __init__(self, parent=None):
        super(Glavni, self).__init__()
        self.ui=Ui_MainWindow()
        self.ui.setupUi(self)
        self.show()

        #QtCore.QObject.connect(self.ui.actionRegistar, QtCore.SIGNAL("triggered()"), self.popup)
        db = QSqlDatabase.addDatabase("QSQLITE")
        db.setDatabaseName("baza.db")
        db.open()

        projectModel = QSqlQueryModel()
        projectModel.setQuery("select name from people",db)

        projectView = QtGui.QTableView()
        projectView.setModel(projectModel)
        projectView.show()

    def popup(self):
        dialog = QtGui.QDialog()
        dialog.show()

class Dialog(QtGui.QDialog):
    def __init__(self,parent=None):
        super(Dialog,self).__init__()
        self.ui = Ui_Dialog()
        self.ui.setupUi(self)
        self.show()

def main():
    app = QtGui.QApplication(sys.argv)
    prozor = Glavni()
    sys.exit(app.exec_())

if __name__ == '__main__':
    main()

私は何が間違っているのですか?QT DesignerでのQListViewの名前は、関連性がある場合はlistaです。ありがとうございました。

4

1 に答える 1

0
projectView = QtGui.QTableView() #THIS part is wrong if the GUI is designed through Designer
projectView.setModel(projectModel)
projectView.show()

正しいコードは次のようになります。

projectView = self.ui.myList #or some other name, which is the SAME AS that object name in   Designer
projectView.setModel(projectModel)
projectView.show()

そしてそれは動作します;)

于 2012-07-09T18:09:04.383 に答える