1

奇妙な問題があります。次のコードは、2 つのウィジェットを SQLITE テーブルの最初の 2 行 ("simpletable") にのみマップする場合に完全に機能します。ウィジェットは起動時に入力され、ウィジェットを編集してボタンをクリックし、mapper.submit() を呼び出すと、テーブルが正しく更新されます。

ただし、3 番目のウィジェットをマップするとすぐに、起動時にウィジェットの値が適切に入力されますが、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