2 Star 10 Fork 7

终點起點/PySide6-UI-Demo

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
SqlRelationalTableModel.py 1.45 KB
一键复制 编辑 原始数据 按行查看 历史
终點起點 提交于 2024-09-05 14:42 +08:00 . 增加示例
import sys
import os
from PySide6.QtWidgets import *
from PySide6.QtGui import *
from PySide6.QtCore import *
from PySide6.QtSql import *
class Demo(QWidget):
def __init__(self, parent=None):
super().__init__(parent)
self.parent = parent
self.dbFile=os.path.join(self.parent.getAppDir(),'test.db')
layout = QVBoxLayout()
layout.setAlignment(Qt.AlignmentFlag.AlignTop)
toolBar=QToolBar()
btn=QPushButton('Load')
btn.clicked.connect(self.Load)
toolBar.addWidget(btn)
layout.addWidget(toolBar)
db=QSqlDatabase().addDatabase("QSQLITE")
db.setDatabaseName(self.dbFile)
self.model=QSqlRelationalTableModel(db=db)
self.tableView=QTableView()
self.tableView.setModel(self.model)
self.tableView.setItemDelegateForColumn(2,QSqlRelationalDelegate(self.tableView))
#self.tableView.setSelectionBehavior(QTableView.SelectionBehavior.SelectRows)#行选择
layout.addWidget(self.tableView)
self.setLayout(layout)
def Load(self):
self.model.database().open()
self.model.setTable('User')
self.model.setRelation(2,QSqlRelation('City','Id','Name'))#设置外键
self.model.setHeaderData(2,Qt.Orientation.Horizontal,'City')
self.model.select()
self.model.database().close()
def runDemo(parent):
wigdet = Demo(parent)
return wigdet
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Python
1
https://gitee.com/johnjiangw/pyside6-ui-demo.git
git@gitee.com:johnjiangw/pyside6-ui-demo.git
johnjiangw
pyside6-ui-demo
PySide6-UI-Demo
master

搜索帮助