百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

实战PyQt5: 073-表格视图QTableView

wptr33 2024-11-26 09:30 25 浏览

QTableView简介

QTableView是模型-视图(Model-View)框架类之一,是Qt模型-视图框架的组成部分,它实现了一个表格视图。在一个应用需要和一批数据进行交互,需要以表格形式输出这些信息的时候,QTableView是最合适的选择。

QTableView实现了QAbstractItemView类定义的接口,因此它能够显示从QAbstractItemModel类派生的模型提供的数据。

我们可以通过使用鼠标单击某个单元格或者使用箭头来导航表格视图中的单元格。QTableView拥有一个水平表头和垂直标表头。表格视图中显示的条目与其他视图中的条目一样,使用标准委托类来渲染和编辑。

QTableView常用方法:

  • setModel(): 设置视图的Model类;
  • horizontalHeader(): 获得水平表头;
  • verticalHeader(): 获得垂直表头;
  • rowHeight(): 获得每一行的高度;
  • columnWidth(): 获得列的宽度;
  • hideRow(): 隐藏指定行;
  • showRow(): 显示指定行;
  • hideColumn(): 隐藏指定列;
  • showColumn(): 显示指定列;
  • selectRow(): 选择指定行;
  • selectColumn(): 选择指定列。

QTableView类继承关系:

测试QTableView

在测试代码中,我们使用QStandardItemModel作为QTableView的模型类, 对视图的属性做了一些限制(只能选中一行,只允许行选中模式,不可编辑等等)。当我们选中某一行是,在状态条上添加信息显示,在菜单栏实现了添加行和删除行的功能。完整代码如下:

import sys
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtCore import Qt,QItemSelection, QItemSelectionModel, QModelIndex
from PyQt5.QtGui import QStandardItemModel, QStandardItem
from PyQt5.QtWidgets import (QApplication, QMainWindow, QTableView,
                             QAbstractItemView, QHeaderView, QMenu, QMenuBar, QAction)
 
class DemoTableView(QMainWindow):
    def __init__(self, parent=None):
        super(DemoTableView, self).__init__(parent)   
        
         # 设置窗口标题
        self.setWindowTitle('实战PyQt5: QTableView 演示')      
        # 设置窗口大小
        self.resize(520, 360)
      
        self.initUi()
        
    def initUi(self):
        
        #行数和列数
        self.rows = 8
        self.cols = 4
        
        #设置水平表头信息
        model = QStandardItemModel(self.rows, self.cols, self)
        hTitle=[]
        for col in range(self.cols):
            hTitle.append('第{}列'.format(col+1))
        model.setHorizontalHeaderLabels(hTitle)
        #设置垂直表头信息
        vTitle=[]
        for row in range(self.rows):
            vTitle.append('第{}行'.format(row+1))
        model.setVerticalHeaderLabels(vTitle)
        
        #设置Item里的内容
        for row in range (self.rows):
            for column in range (self.cols):
                item = QStandardItem('(row %s, column %s)'%(row, column))
                model.setItem(row, column, item)
        
        tableView = QTableView(self)
        tableView.setModel(model)
        #设置只能选中一行
        tableView.setSelectionMode(QAbstractItemView.SingleSelection)
        #不可编辑
        tableView.setEditTriggers(QTableView.NoEditTriggers)
        #设置只有行选中
        tableView.setSelectionBehavior(QAbstractItemView.SelectRows)
        #所有列自动拉伸,充满界面
        tableView.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch)
        
        #显示选中行的信息
        tableView.selectionModel().currentChanged.connect(self.onCurrentChanged)
                
        self.model = model
        self.tableView = tableView
        self.setCentralWidget(tableView)
    
        #添加菜单项
        menuBar = self.menuBar()
        fileMenu = menuBar.addMenu('文件')
        editMenu = menuBar.addMenu('编辑')
        
        #退出应用
        appExit = QAction('退出', self)
        appExit.triggered.connect(self.close)
        fileMenu.addAction(appExit)
        
        #添加一行
        editAppend = QAction('添加', self)
        editAppend.triggered.connect(self.appendRow)
        #删除一行
        editRemove = QAction('删除', self)
        editRemove.triggered.connect(self.removeRow)
        editMenu.addAction(editAppend)
        editMenu.addAction(editRemove)
        
    def appendRow(self):
        row = self.model.rowCount()
        items = list()
        for col in range (self.cols):
            items.append(QStandardItem('(row %s, column %s)'%(row, col)))
        #添加一行
        self.model.appendRow(items)
        #更新头信息
        self.model.setVerticalHeaderItem(row, QStandardItem('第{}行'.format(row+1)))
    
    def removeRow(self):
        #获取选中的行
        sel = self.tableView.selectionModel().selectedRows()
        print(sel)
        if sel:
            #下面删除时,选中多行中的最后一行,会被删掉;不选中,则默认第一行删掉
            index=self.tableView.currentIndex()
            print(index.row())
            self.model.removeRow(index.row())
            
    def onCurrentChanged(self,current, previous):
        #初始化时,previous.row() = -1,不显示信息
        if int(previous.row() < 0):
             return
        self.statusBar().showMessage('选中第{}行'.format(current.row()+1))
    
if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = DemoTableView()
    window.show()
    sys.exit(app.exec()) 

运行结果如下图:

本文知识点

  • QTableView的行和列的属性设置;
  • QTableView的选择属性的设置;
  • QTableView水平和垂直表头信息设置;
  • 在QTableView中添加或者删除一行。

喜欢本文内容就关注, 收藏,点赞,评论和转发。

相关推荐

一篇文章带你了解PHP的学习使用(php的教程)

ThinkPHP5实战...

在memcached管理php的session(memcached libevent)

PHP的session(会话管理)一般是以文件形式进行,而在多个Web服务器之间进行session管理时memecached会比文件管理方式更加方便。在这里介绍如何使用memcached管理PHP的s...

php传值和传引用的区别(php 传值和传引用)

php传值:在函数范围内,改变变量值得大小,都不会影响到函数外边的变量值。PHP传引用:在函数范围内,对值的任何改变,在函数外部也有所体现,因为传引用传的是内存地址。传值:和copy是一样的。【打个比...

PHP 常量详解教程(php常量和变量)

常量类似变量,但是常量一旦被定义就无法更改或撤销定义。PHP常量常量是单个值的标识符(名称)。在脚本中无法改变该值。有效的常量名以字符或下划线开头(常量名称前面没有$符号)。注释:与变量不同,常...

php自学零基础入门小知识(php新手入门教程)

我们就把PHP入门当成一个苹果吧!一口一口的吃掉他!不啰嗦了!开始了1、嵌入方法:类似ASP的<%,PHP可以是<?php或者是<?,结束符号是?>,当然您也可以自己指定。2、...

PHP 语法详解(php语法大全)

PHP脚本在服务器上执行,然后向浏览器发送回纯HTML结果。基础PHP语法PHP脚本可放置于文档中的任何位置。PHP脚本以<?php开头,以?>结尾:<?php...

PHP笔记(一)PHP基础知识(php必背知识点)

创建PHP程序PHP代码框架<?php>2.文件命名规则...

PHP 8新特性之Attributes(注解),你掌握了吗?

PHP8的Alpha版本,过几天就要发布了,其中包含了不少的新特性,当然我自己认为最重要的还是JIT,这个我从2013年开始参与,中间挫折无数,失败无数后,终于要发布的东东。不过,今天呢,我不打算谈J...

PHP基本语法之标记与注释(php注释规范)

1、标记由于PHP是嵌入式脚本语言,它在实际开发中经常会与HTML内容混在一起,所以为了区分HTML与PHP代码,需要使用标记对PHP代码进行标识。如:<html>...

php注解(PHP注解 性能)

目标了解和使用php注解,如果你已经掌握其他一种具有注解的语言,例如:java、python等,你在本文中只需要了解点语法就行。示例php8以前的版本,注解写在注释里,如果你掌握其他语言的注解,你是不...

数据丢失?别慌!MySQL备份恢复攻略

想象一下,某个晴朗的午后,你正享受着咖啡,突然接到紧急电话:你的网站或APP彻底挂了!系统崩溃,界面全白。虽然心头一紧,但你或许还能安慰自己:系统崩溃只是暂停服务,数据还在,修复修复就好了。然而,如果...

MySQL 日志:undo log、redo log、binlog

今天来和大家分享MySQL的三个日志文件,可以说MySQL的多数特性都是围绕日志文件实现,而其中最重要的有以下三种:...

MySQL三大日志:binlog、redolog、undolog全解析

binlog概述在MySQL数据库中,binlog可是个相当重要的存在,它的全称为binarylog,也就是二进制日志。它就像是数据库的“记忆本”,记录了所有的DDL(数据定义语言)和...

1、MySQL数据库介绍(mysql数据库简单介绍)

1.1数据库的核心定义数据库的本质数据库乃存储数据对象之容器,涵盖如下关键组件:表(Table)...

MySQL 日志双雄:实时监控与历史归档实战优化

MySQL日志双雄:实时监控+历史归档实战用这招让你家日志系统再也不卡不爆炸MySQL十亿级日志处理:从洪峰到归档全攻略手把手教你用MySQL搞定ELK级日志监控在微服务架构大行其道的今天,日志系统早...