В одном из постов данного блога был пост на тему использования Базы Данных из PySide. Теперь постараемся расширить тот скрипт и приделать к полям таблицы редактируемые элементы управления.
Для этого нам понадобится класс QDataWidgetMapper. Этот класс реализует связь между моделью таблицы и элементами управления.
Сначала нужно будет создать объект QDataWidgetMapper. Связать его с моделью использую функцию setModel() и связать поля модели с элементами управления на форме. Пример.
Для этого нам понадобится класс 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_())
Вот то что должно получится в итоге.

Прямо в гриде
ОтветитьУдалить