在MainUi()类中,我们创建一个名为create_db()的方法:
# 创建数据库 def create_db(self): try: # 调用输入框获取数据库名称 db_text,db_action = QtWidgets.QInputDialog.getText(self,'数据库名称','请输入数据库名称',QtWidgets.QLineEdit.Normal) if (db_text.replace(' ','') != '') and (db_action is True): print(db_text) self.db_name = db_text # 添加一个sqlite数据库连接并打开 db = QtSql.QSqlDatabase.addDatabase('QSQLITE') db.setDatabaseName('{}.sqlite'.format(db_text)) db.open() # 实例化一个查询对象 query = QtSql.QSqlQuery() # 创建一个数据库表 query.exec_("create table zmister(ID int primary key, " "site_name varchar(20), site_url varchar(100))") # 插入三条数据 query.exec_("insert into zmister values(1000, '州的先生', 'https://zmister.com')") query.exec_("insert into zmister values(1001, '百度', 'http://www.baidu.com')") query.exec_("insert into zmister values(1002, '腾讯', 'http://www.qq.com')") print('创建数据库成功') except Exception as e: print(e)
在这个方法中,我们自定义数据库名并创建一个sqlite数据库,然后在这个数据库中创建了一个名为zmister的数据库表,最后在zmister数据库表中插入了三条数据。
接下来,我们将这个方法绑定到【创建数据库】按钮的点击事件上:
self.b_create_db.clicked.connect(self.create_db)
这样,当我们点击【创建数据库】按钮的时候,UI界面会弹出一个文本输入框供我们输入数据库的名称,然后创建一个数据表并插入数据:
完成操作之后,会发现文件同级目录下多出了一个zmister.sqlite文件,我们使用SQLite Expert等SQLite数据库可视化软件打开它:
这样,我们就成功在PyQt5中创建连接并写入操作了一个数据库。
在UI界面查看和修改数据
上面我们创建了一个SQLite数据库并在其中写入了三条数据,如何将数据表中的数据显示在UI界面中呢。我们可以借助QSqlTableModel类来实现。
还记得我们在创建UI界面的时候,在界面的右方放置了一个QTableView()部件,我们的数据库数据将显示在这上面。
继续在MainUi()类中创建一个名为view_data()的方法,在方法中实例化一个QSqlTableModel(),并将QTableView()部件的model模型设置为实例化后的QSqlTableModel():
# 浏览数据 def view_data(self): # 实例化一个可编辑数据模型 self.model = QtSql.QSqlTableModel() self.table_widget.setModel(self.model) self.model.setTable('zmister') # 设置数据模型的数据表 self.model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange) # 允许字段更改 self.model.select() # 查询所有数据 # 设置表格头 self.model.setHeaderData(0,QtCore.Qt.Horizontal,'ID') self.model.setHeaderData(1, QtCore.Qt.Horizontal, '站点名称') self.model.setHeaderData(2, QtCore.Qt.Horizontal, '站点地址')
然后,将view_data()方法绑定在UI界面的【浏览数据】按钮的点击事件中:
self.b_view_data.clicked.connect(self.view_data)
这样,我们在点击【浏览数据】按钮的时候,会将zmister表中的所有数据显示出来:
除了简单的将数据显示在UI界面上,我们还可以直接在UI界面上修改数据:
添加和删除数据
完成查和改的SQL操作之后,我们接着来了解一下如何添加数据和删除数据。
添加数据通过数据模型对象的insertRows()方法来实现,删除数据则通过数据模型对象的removeRow()方法来实现。
我们继续在MainUi()类中创建两个方法:add_row_data()和del_row_data():
# 添加一行数据行 def add_row_data(self): # 如果存在实例化的数据模型对象 if self.model: self.model.insertRows(self.model.rowCount(), 1) else: self.create_db() # 删除一行数据 def del_row_data(self): if self.model: self.model.removeRow(self.table_widget.currentIndex().row()) else: self.create_db()
然后将这两个方法分别绑定在【添加一行】和【删除一行】按钮的点击事件上:
self.b_add_row.clicked.connect(self.add_row_data) self.b_delete_row.clicked.connect(self.del_row_data)
这样就实现了UI界面上的添加数据和删除数据:
这样,我们就基本实现了使用PyQt5对数据库的增删改查操作,更加详细的使用和说明请参考Qt文档。
到此这篇关于Python GUI教程之在PyQt5中使用数据库的方法的文章就介绍到这了,更多相关PyQt5使用数据库内容请搜索
标签:SQLite
相关阅读 >>
更多相关阅读请进入《Sqlite》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。