【PyQt】19-数据操作<表格>


前言


一、显示二维表数据(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_())

总结

这篇文章依旧没有总结

  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值