28 июня 2012 г.

Пример использования QDataWidgetMapper в PySide

В одном из постов данного блога был пост на тему использования Базы Данных из PySide. Теперь постараемся расширить тот скрипт и приделать к полям таблицы редактируемые элементы управления.
Для этого нам понадобится класс QDataWidgetMapper. Этот класс реализует связь между моделью таблицы и элементами управления.
Сначала нужно будет создать объект QDataWidgetMapper. Связать его с моделью использую функцию setModel() и связать поля модели с элементами управления на форме. Пример.
# coding=utf-8
import sys

from PySide import QtGui, QtSql, QtCore

#приложение
main=QtGui.QApplication(sys.argv)
#подключение база
dbase = QtSql.QSqlDatabase.addDatabase('QSQLITE')
#файл базы
dbase.setDatabaseName('my_db.sqlite') 
dbase.open()
query=QtSql.QSqlQuery()
#Создаем базу
query.exec_('''CREATE TABLE forms 
                (id integer PRIMARY KEY AUTOINCREMENT UNIQUE NOT NULL, 
                name VARCHAR(9));''')
query.exec_('''CREATE TABLE studients 
                (id integer PRIMARY KEY AUTOINCREMENT UNIQUE NOT NULL, 
                name VARCHAR(255), 
                form_id integer,
                FOREIGN KEY (form_id ) REFERENCES forms);''')



class Form(QtGui.QWidget):
    def __init__(self, parent=None):
        # Создаем кнопки, поля, грди для работы с данными
        super(Form, self).__init__(parent)     
        self.gridLayout = QtGui.QGridLayout(self)
        self.gridLayout.setContentsMargins(5, 5, 5, 5)
        self.label = QtGui.QLabel('ID')
        self.gridLayout.addWidget(self.label, 0, 0, 1, 1)
        self.lineEdit = QtGui.QLineEdit()
        self.gridLayout.addWidget(self.lineEdit, 0, 1, 1, 2)
        self.label_2 = QtGui.QLabel('Name')
        self.gridLayout.addWidget(self.label_2, 1, 0, 1, 1)
        self.lineEdit_2 = QtGui.QLineEdit()
        self.gridLayout.addWidget(self.lineEdit_2, 1, 1, 1, 2)
        
        self.button_prev = QtGui.QPushButton('Prev')
        self.gridLayout.addWidget(self.button_prev, 2, 1, 1, 1)
        self.button_next = QtGui.QPushButton('Next')
        self.setLayout(self.gridLayout)
        self.gridLayout.addWidget(self.button_next, 2, 2, 1, 1) 
        self.view = QtGui.QTableView()
        self.gridLayout.addWidget(self.view, 3, 1,1,2)
        self.bind_data()
        
    def bind_data(self):
        #типа DBGird
        
        #типа Tabel
        self.model = QtSql.QSqlTableModel()
        self.model.setTable('forms')
        
        self.model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
        #Связываем грид с таблицой
        self.view.setModel(self.model)
        
        self.data_mapper = QtGui.QDataWidgetMapper()
        # связиваем мапер с таблицой
        self.data_mapper.setModel(self.model)
        #Связываем поля
        self.data_mapper.addMapping(self.lineEdit, 0)
        self.data_mapper.addMapping(self.lineEdit_2, 1)
        self.model.select()
        self.data_mapper.toFirst()
        
        # переход между записями по книпкам
        self.connect(self.button_next, QtCore.SIGNAL('clicked()'), self.data_mapper.toNext)
        self.connect(self.button_prev, QtCore.SIGNAL('clicked()'), self.data_mapper.toPrevious)
        
my_win = Form()
my_win.show()
sys.exit(main.exec_())
Вот то что должно получится в итоге.


1 комментарий: