Вставка строки в QTableView - PullRequest
0 голосов
/ 15 мая 2018

У меня есть родительская таблица PostgreSQL под названием «комнаты» и связанная таблица под названием «конфигурации». У меня есть форма, которая позволит пользователю добавлять редактирование и добавлять новые конфигурации в отдельные комнаты в QTableView. В таблице конфигурации комната - это внешний ключ к таблице комнат. Форма выглядит так:

enter image description here

Что касается редактирования конфигураций, то, похоже, проблем нет. Проблема возникает, когда я добавляю новую запись в модель конфигурации. Если я вставлю строку и не установлю ячейку комнаты, пользователь сможет редактировать любое из полей, и оно сохранится в базе данных. Хотя по окончании редактирования строка очищается и! появляется в заголовке строки. Если я перезагружаю форму, запись редактируется правильно.

Однако я хочу установить номер комнаты для пользователя и оставить поле номера комнаты в представлении конфигурации скрытым от пользователя. Когда я добавляю строку и устанавливаю значение ячейки с номером комнаты, я не могу редактировать строку. Есть идеи?

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
from PyQt5.QtSql import *
from rooms import *
from config import *


class Setup_rooms(QDialog):
    def __init__(self):
        QDialog.__init__(self)
        self.ui = Ui_rooms_setup()
        self.ui.setupUi(self)

        self.rooms_model = QSqlRelationalTableModel(self)
        self.rooms_model.setTable('rooms')
        self.rooms_model.setRelation(4, QSqlRelation('room_types1', 'room_type', 'room_type'))
        self.rooms_model.setSort(int(self.rooms_model.fieldIndex("room")), Qt.AscendingOrder)
        self.rooms_model.select()
        self.rooms_mapper = QDataWidgetMapper(self)
        self.rooms_mapper.setSubmitPolicy(QDataWidgetMapper.AutoSubmit)
        self.rooms_mapper.setModel(self.rooms_model)
        self.rooms_mapper.setItemDelegate(QSqlRelationalDelegate(self))
        self.rooms_mapper.addMapping(self.ui.room_num, self.rooms_model.fieldIndex("room"))
        self.rooms_mapper.addMapping(self.ui.room_description, self.rooms_model.fieldIndex("description"))
        self.rooms_mapper.addMapping(self.ui.deep_clean_date, self.rooms_model.fieldIndex("deepcleandate"))
        self.rooms_mapper.addMapping(self.ui.deep_clean_cycle, self.rooms_model.fieldIndex("deepcleancycle"))
        room_types_model = self.rooms_model.relationModel(4)
        self.ui.room_type.setModel(room_types_model)
        self.ui.room_type.setModelColumn(room_types_model.fieldIndex('room_type'))
        self.rooms_mapper.addMapping(self.ui.room_type, self.rooms_model.fieldIndex('room_type'))
        self.rooms_mapper.toFirst()
        self.ui.current_index.setText(str(self.rooms_mapper.currentIndex()))

        self.config_model = QSqlRelationalTableModel(self)
        self.config_model.setTable('room_configurations')
        self.config_model.setRelation(self.config_model.fieldIndex("configuration"), QSqlRelation('configurations', 'configuration', 'configuration'))
        self.room_model = self.config_model.relationModel(self.config_model.fieldIndex('room'))
        self.config_view = self.ui.configurations
        self.config_view.setModel(self.config_model)
        self.config_view.horizontalHeader().setStretchLastSection(True)
        self.config_model.select()
        self.config_model.setHeaderData(self.config_model.fieldIndex("sort_order"), Qt.Horizontal, "sort order")
        self.config_view.setItemDelegate(View_room_config(self))
        self.config_view.setItemDelegate(QSqlRelationalDelegate(self.config_view))
        self.config_view.resizeColumnsToContents()
        room = self.rooms_model.record(self.rooms_mapper.currentIndex()).value('room')
        self.config_model.setFilter("room = '{0}'".format(room))

        #self.config_view.setColumnHidden(0, True)
        #self.config_view.setColumnHidden(2, True)

        self.ui.add_config.clicked.connect(self.add_config)


    def add_config(self):
        row=int(self.config_model.rowCount()) 
        self.config_model.insertRow(row) 
        self.index = QModelIndex(self.config_model.index(row, 2)) 
        self.config_model.setData(self.index, self.ui.room_num.text(), Qt.EditRole)



class View_room_config(QSqlRelationalDelegate):
    def __init__(self, parent=None):
        QItemDelegate.__init__(self)

    def createEditor(self, parent, option, index):
        if index.column() == 3:
            combo = super().createEditor(parent, option, index)


if __name__=="__main__":
    app=QApplication(sys.argv)
    db = QSqlDatabase.addDatabase("QPSQL")
    db.setHostName(host)
    db.setDatabaseName(database)
    db.setUserName(user)
    db.setPassword(password)
    if (db.open()==False):
        QMessageBox.critical(None, "Database Error", db.lastError().text())
    myapp = Setup_rooms()
    myapp.show()
    sys.exit(app.exec_())

1 Ответ

0 голосов
/ 16 мая 2018

Я вроде разобрался с моей проблемой. Я восстановил резервную копию базы данных в области разработки. Я не знаю каких-либо базовых таблиц, которые могли бы вызвать проблему, но моя теория заключается в том, что произошла ошибка базы данных. Сейчас я проверяю ошибки на self.config_model, используя self.config_model.lastError (). Text (), но я не нашел ни одной.

Тем не менее, без изменения моего кода программа работает, хотя пользовательский интерфейс при редактировании довольно неуклюжий. Я сейчас посмотрю на это.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...