数据表
前言
一、显示二维表数据(QTableView控件)
数据表的数据来源是Model
意味着 创建一个数据表【QTableView实例】还需要创建数据源【Model】,然后将两者结合。
类似于MVC模式
扩展知识—MVC模式
MVC(Model-View-Controller)是一种软件架构模式,用于将应用程序的逻辑分成三个部分:模型(Model)、视图(View)和控制器(Controller)。
模型(Model):模型代表应用程序的数据和业务逻辑,负责处理数据的存储、检索和更新。在MVC模式中,模型并不依赖于视图或控制器,这使得它可以独立于用户界面进行测试和修改。
视图(View):视图是用户界面的表示,负责将模型中的数据以用户友好的方式呈现给用户。视图依赖于模型,但不会直接影响数据,通常通过观察模型的变化来更新界面。
控制器(Controller):控制器充当模型和视图之间的桥梁,负责处理用户输入和交互。控制器接收用户的操作,更新模型数据,并通知视图更新以反映这些变化。
MVC模式的目的是将后端数据和前端界面的耦合度降低.
1.1 代码
'''
#Author :susocool
#Creattime:2024/3/24
#FileName:45-二维表
#Description: 创建一个数据表【QTableView实例】并创建数据源【Model】,然后将两者结合。
'''
import sys,math
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
class TableView( QWidget ):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.setWindowTitle('表格控件的使用')
self.resize(500,300)
self.model = QStandardItemModel(4,3) # 创建一个标准的4行3列的表格
self.model.setHorizontalHeaderLabels(['id',
'姓名',
'年龄']) # 行标题
self.tableview = QTableView(self)
# 关联QTableView控件和Model模型
self.tableview.setModel(self.model)
# 添加数据
item11 = QStandardItem("001")
item12 = QStandardItem("江停")
item13 = QStandardItem("33")
self.model.setItem(0,0,item11)
self.model.setItem(0,1,item12)
self.model.setItem(0,2,item13)
item21 = QStandardItem("001")
item22 = QStandardItem("严峫")
item23 = QStandardItem("31")
self.model.setItem(2, 0, item21)
self.model.setItem(2, 1, item22)
self.model.setItem(2, 2, item23)
# 布局
layout = QVBoxLayout()
layout.addWidget(self.tableview)
self.setLayout(layout)
# 让表格自动调整列宽和行高
# self.tableview.resizeColumnsToContents ()
# self.tableview.resizeRowsToContents()
if __name__ == '__main__':
app = QApplication(sys.argv)
ui = TableView()
ui.show()
sys.exit(app.exec_())
1.2 运行结果
我觉得这个是初次接触到表格的相关控件,值得反复观看。这里有必要区分一下QWidget 和 QMainWindow控件。
二、显示列数据(QListView控件)
2.1 代码
'''
#Author :susocool
#Creattime:2024/3/24
#FileName:46-显示列数据
#Description:
'''
import sys,math
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
class TableView( QWidget ):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.setWindowTitle('表格控件的使用')
self.resize(500,300)
listview = QListView()
listModel = QStringListModel()
self.list = ["列表项1","列表项2","列表项3"]
# 关联
listModel.setStringList(self.list)
listview.setModel(listModel)
listview.clicked.connect(self.clicked)
layout = QVBoxLayout()
layout.addWidget(listview)
self.setLayout(layout)
def clicked(self,item):
QMessageBox.information(self,"QListView","您选择了:"+ self.list[item.row()])
if __name__ == '__main__':
app = QApplication(sys.argv)
ui = TableView()
ui.show()
sys.exit(app.exec_())
2.2 运行结果
2.3 扩展—列表控件(QListWidget)
功能更多
'''
#Author :susocool
#Creattime:2024/3/24
#FileName:47-列控件扩展
#Description:
'''
import sys,math
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
class ListWidgetView( QMainWindow ):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.setWindowTitle('列表控件的使用')
self.resize(500,300)
self.listwidget = QListWidget()
# self.listwidget.resize(300,120)
self.listwidget.addItem("item1")
self.listwidget.addItem("item2")
self.listwidget.addItem("item3")
self.listwidget.addItem("item4")
self.listwidget.addItem("item5")
self.setCentralWidget(self.listwidget)
self.listwidget.itemClicked.connect(self.clicked)
def clicked(self,Index):
QMessageBox.information(self,"QListWidget","您选择了:"+self.listwidget.item(self.listwidget.row(Index)).text())
if __name__ == '__main__':
app = QApplication(sys.argv)
ui = ListWidgetView()
ui.show()
sys.exit(app.exec_())
运行结果
2.4 扩展-列表控件QTableWidget
2.4.1 QTableWidget的介绍
QTableWidget 是 PyQt5 中的一个小部件,用于显示二维表格数据。它提供了一种在界面中展示和编辑表格数据的方式,主要作用包括但不限于:
- 显示和编辑表格数据: 可以在表格中显示和编辑各种类型的数据,如文本、数字、图像等。
- 支持多行和多列: 可以根据需要设置表格的行数和列数,并对每个单元格进行操作。
- 设置表头: 支持设置水平和垂直方向的表头,以便用户能够快速了解每列和每行的含义。
- 单元格定制: 可以对单元格进行定制,包括设置文本对齐方式、背景色、字体样式等,以美化和优化数据展示效果。
- 事件处理: 可以捕获用户与表格交互时触发的事件,如单击、双击、键盘输入等,从而实现特定的交互逻辑。
- 与其他部件集成: 可以与其他 PyQt5 小部件集成,如按钮、复选框等,实现更复杂的用户界面交互和数据处理功能。
2.4.2 对比QTableView 和 QTableWidget的异同
QTableView 和 QTableWidget 都是用于显示表格数据的 PyQt5 小部件,它们有一些重要的异同点:
-
相同点:
- 显示表格数据: 二者都可以用于在界面中显示二维表格数据,支持多行和多列的显示。
- 支持表头: 都支持设置水平和垂直方向的表头,以便用户能够识别每列和每行的含义。
- 数据定制: 可以对单元格进行定制,如设置文本对齐方式、背景色、字体样式等。
- 事件处理: 都可以捕获用户与表格交互时触发的事件,如单击、双击、键盘输入等。
-
不同点:
- 数据模型:
- QTableWidget: 是一个自包含的部件,数据直接存储在部件本身。
- QTableView: 需要通过设置数据模型(如 QStandardItemModel)来管理和显示数据,数据和视图分离,更灵活和可扩展。
- 灵活性:
- QTableWidget: 适合用于简单的表格显示和编辑,特别适合于快速开发简单表格应用。
- QTableView: 更适合于复杂的表格需求,因为它允许使用自定义的数据模型,支持更高级的数据管理和显示控制。
- 复杂性:
- QTableWidget: 使用简单,不需要额外设置数据模型,适合快速实现基本的表格功能。
- QTableView: 使用更复杂,但能够实现更高级和定制化的表格功能,如排序、筛选等。
- 数据模型:
总结:
如果你只需简单地显示和编辑表格数据,并且不需要复杂的数据处理和显示控制,可以选择使用 QTableWidget。
如果你需要更灵活和高级的表格功能,如自定义数据模型、排序、筛选等,应该选择 QTableView,并结合适当的数据模型来实现你的需求。
2.4.3 简单展示
2.4.3.1 代码
'''
#Author :susocool
#Creattime:2024/6/28
#FileName:047-1-扩展列表控件’
#Description: 扩展列表控件QTableWidget
'''
import sys,math
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
class TalbelWidgetdemo(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.setWindowTitle('QTalbelWidget的使用')
self.resize(500,300)
layout = QHBoxLayout() # 设置水平布局
tabelWdiget = QTableWidget() # 创建QTableWidget对象
tabelWdiget.setRowCount(4) # 设置行数
tabelWdiget.setColumnCount(3) # 设置列数
layout.addWidget(tabelWdiget) # 将QTableWidget添加到布局中
# 这里要记住有多个内容的时候一定要加s!
tabelWdiget.setHorizontalHeaderLabels(["姓名","性别","年龄"]) # 设置表头
# 设置单元格内容
nameItems = ["张三","李四","王五","赵六"]
sexItems = ["男","女","男","女"]
ageItems = [20,21,22,23]
for i in range(4):
item = QTableWidgetItem(nameItems[i])
item.setTextAlignment(Qt.AlignCenter) # 设置内容居中
tabelWdiget.setItem(i,0,item)
item = QTableWidgetItem(sexItems[i])
item.setTextAlignment(Qt.AlignCenter) # 设置内容居中
tabelWdiget.setItem(i,1,item)
item = QTableWidgetItem(str(ageItems[i]))
item.setTextAlignment(Qt.AlignCenter) # 设置内容居中
tabelWdiget.setItem(i,2,item)
self.setLayout(layout)
if __name__ == '__main__':
app = QApplication(sys.argv)
examlp = TalbelWidgetdemo()
examlp.show()
sys.exit(app.exec_())
2.4.3.2 运行结果
此时的表格内容是可以被修改的
修改后部的展示
-
禁止被编辑
# 禁止编辑 tabelWdiget.setEditTriggers(QAbstractItemView.NoEditTriggers)
添加这句之后就可以禁止编辑内容
-
设置含行列大小根据内容进行展示
在这里我好像明白他的用法了,就是带s的就是很多的Row(列)被设置成为根据内容进行带下调整,而没有s的代表就是单个的Row,可与i被指定是哪个Row。
太丑了,我待会一定要注释掉这个。
ctrl+/ 进行快速注释【就是全打#的那个】 -
隐藏标题
# 隐藏水平\垂直标题 tabelWdiget.horizontalHeader().setVisible(False) tabelWdiget.verticalHeader().setVisible(False)
-
设置水平标题
# 设置列的标题(默认123) tabelWdiget.setVerticalHeaderLabels(["a","b","c","d"])
-
隐藏表格线
# 隐藏表格线
tabelWdiget.setShowGrid(False)
完整代码
'''
#Author :susocool
#Creattime:2024/6/28
#FileName:047-1-扩展列表控件’
#Description: 扩展列表控件QTableWidget
'''
import sys,math
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
class TalbelWidgetdemo(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.setWindowTitle('QTalbelWidget的使用')
self.resize(500,300)
layout = QHBoxLayout() # 设置水平布局
tabelWdiget = QTableWidget() # 创建QTableWidget对象
tabelWdiget.setRowCount(4) # 设置行数
tabelWdiget.setColumnCount(3) # 设置列数
layout.addWidget(tabelWdiget) # 将QTableWidget添加到布局中
# 这里要记住有多个内容的时候一定要加s!
tabelWdiget.setHorizontalHeaderLabels(["姓名","性别","年龄"]) # 设置表头
# 设置单元格内容
nameItems = ["张三","李四","王五","赵六"]
sexItems = ["男","女","男","女"]
ageItems = [20,21,22,23]
for i in range(4):
item = QTableWidgetItem(nameItems[i])
item.setTextAlignment(Qt.AlignCenter) # 设置内容居中
tabelWdiget.setItem(i,0,item)
item = QTableWidgetItem(sexItems[i])
item.setTextAlignment(Qt.AlignCenter) # 设置内容居中
tabelWdiget.setItem(i,1,item)
item = QTableWidgetItem(str(ageItems[i]))
item.setTextAlignment(Qt.AlignCenter) # 设置内容居中
tabelWdiget.setItem(i,2,item)
# 禁止编辑
tabelWdiget.setEditTriggers(QAbstractItemView.NoEditTriggers)
# 行列内容根据内容进行调整
# tabelWdiget.resizeColumnsToContents()
# tabelWdiget.resizeRowsToContents()
# 设置列的标题(默认123)
tabelWdiget.setVerticalHeaderLabels(["a","b","c","d"])
# 隐藏水平\垂直标题
# tabelWdiget.horizontalHeader().setVisible(False)
# tabelWdiget.verticalHeader().setVisible(False)
# 隐藏表格线
tabelWdiget.setShowGrid(False)
self.setLayout(layout)
if __name__ == '__main__':
app = QApplication(sys.argv)
examlp = TalbelWidgetdemo()
examlp.show()
sys.exit(app.exec_())
总结
这篇文章依旧没有总结