1

我有一个奇怪的问题。如果我只将两个小部件映射到 SQLITE 表的前两行(“simpletable”),则以下代码可以完美运行。小部件在启动时填充,当我编辑小部件并单击按钮并调用 mapper.submit() 时,表格已正确更新。

但是,一旦我映射了第三个小部件,小部件值就会在启动时正确填充,但是在调用 mapper.submit() 时出现错误并且不再有映射工作。

“simpletable”只是一组带有文本值的简单行和列:

"simpletable"
a1 b1 c1 d1
a2 b2 c2 d2
a3 b3 c3 d3

当方向设置为水平时,列被正确映射并且一切正常。关于问题可能是什么的任何建议?

from PyQt4 import QtGui, QtCore, QtSql
import sys

def mapValues(mapper):
    if not mapper.submit():
        print "error!"
    else:
        print "ok!"
    mapper.toFirst()

if __name__ == '__main__':

    app = QtGui.QApplication(sys.argv)
    mw = QtGui.QWidget()
    db = QtSql.QSqlDatabase.addDatabase("QSQLITE")
    db.setDatabaseName("demo_mapper.db")
    if not db.open():
        print "did not open"
    model = QtSql.QSqlTableModel()
    model.setTable("simpletable")
    model.select()
    model.submitAll()

    view = QtGui.QTableView()
    view.setModel(model)

    mapper = QtGui.QDataWidgetMapper()
    mapper.setSubmitPolicy(QtGui.QDataWidgetMapper.ManualSubmit)
    mapper.setModel(model)
    mapper.setOrientation(QtCore.Qt.Vertical)
    mapper.setCurrentIndex(0)

    vbox = QtGui.QVBoxLayout()
    vbox.addWidget(view)

    qlinePropValue_0 = QtGui.QLineEdit()
    qlinePropValue_1 = QtGui.QLineEdit()
    qlinePropValue_2 = QtGui.QLineEdit()

    mapper.addMapping(qlinePropValue_0, 0)
    mapper.addMapping(qlinePropValue_1, 1)

    ### ERROR HAPPENS IF LINE BELOW IS INCLUDED ###
    ### NO ERROR IF LINE BELOW IS COMMENTED OUT
    mapper.addMapping(qlinePropValue_2, 2)

    mapper.toFirst()

    view = QtGui.QTableView()
    view.setModel(model)

    vbox.addWidget(qlinePropValue_0)
    vbox.addWidget(qlinePropValue_1)
    vbox.addWidget(qlinePropValue_2)

    mybutton = QtGui.QPushButton()
    mybutton.setText("Press Me")
    mybutton.clicked.connect(lambda: mapValues(mapper))
    vbox.addWidget(mybutton)

    mw.setLayout(vbox)
    mw.show()

    sys.exit(app.exec_())
4

0 回答 0