首页 最新 热门 推荐

  • 首页
  • 最新
  • 热门
  • 推荐

第15.25节 PyQt(Python+Qt)入门学习:Model/View开发实战--使用QTableView展示Excel文件内容

  • 23-09-22 12:43
  • 2660
  • 10515
blog.csdn.net
  • 老猿Python博文目录
  • 专栏:使用PyQt开发图形界面Python应用
  • 老猿Python博客地址

一、概述

在前面的订阅专栏《第十九章、Model/View开发:QTableView的功能及属性》及公开博文《第15.24节 PyQt(Python+Qt)入门学习:Model/View架构中QTableView的作用及属性详解》中介绍了QTableView的主要功能及属性,本节来使用QTableView与QStandardItemModel配套来开发一个简单的Excel文件展示程序。之所以使用QStandardItemModel,这是因为在Model/View架构中,PyQt和Qt提供的已经可以直接使用的model模型类中,QStandardItemModel应该是最适合QTableView的模型。

二、QStandardItemModel相关知识介绍

下面介绍几个本节需要使用的QStandardItemModel的方法。

2.1、项QStandardItem

2.1.1、项的创建

QStandardItemModel是一个多用途模型,可用于表示列表list、表table和树tree类型视图所需的各种不同数据结构,模型可以保存数据项。

QStandardItemModel的项是QStandardItem类的实例对象,创建项的语法如下:

  • QStandardItem():创建一个无数据的空项,可以通过setData方法指定数据
  • QStandardItem(str text) :创建一个带数据text的项
  • QStandardItem(QIcon icon, str text):创建一个带图标和数据的项,即项可以在视图中同时展现图标和数据
  • QStandardItem(int rows, int columns = 1):创建包含rows行,columns列的项阵

2.1.2、数据修改方法

项创建以后可以使用setData方法修改数据项,包括修改数据、数据图标、数据复选状态以及数据的拖拽状态等。

语法:setData( QVariant value, int role = Qt.UserRole + 1)
  • 1

QVariant 代表任何PyQt或Qt的类型,QVariant 构造方法使用任何类型的数据作为参数就可以转换为QVariant类型。

关于role的取值在前面章节《第十四章、Model/View开发:Model/View架构程序设计模式》和《PyQt学习随笔:Model/View中诸如DisplayRole的数据角色及含义》进行了介绍,在此不重复介绍。

2.2、QStandardItemModel构造方法

QStandardItemModel的构造方法有2个,分别如下

  • QStandardItemModel(QObject parent = None):直接创建一个模型实例,数据未进行初始化
  • QStandardItemModel(int rows, int columns, QObject parent = None):直接创建一个模型实例,包含有rows行columns列的空项。这些项可以通过model的index方法获取后,通过QModelIndex的setData方法进行数据修改。当模型中存储实际数据少于指定的行或列时,多出部分显示空数据。

2.3、setColumnCount方法

setColumnCount设置模型中数据的列数为指定数目,如果模型本身的列数超过了设定数,则多出的列数被废弃。

语法:QStandardItemModel.setColumnCount(int columns)
  • 1

2.4、setHeaderData方法

setHeaderData方法设置模型中指定部分表头数据的内容。

语法:bool QStandardItemModel.setHeaderData(int section, Qt.Orientation orientation,  QVariant value, int role = Qt.EditRole)
  • 1

2.5、setItem方法

setItem是将model中指定行、列的项设置为参数指定的项。

语法:setItem(int row, int column, QStandardItem item)
  • 1

注意该方法没有返回值。

三、开发实战案例

3.1、案例情况介绍

本案例通过读取指定excel文件第一个sheet的数据,将数据的表头栏及数据在QTableView的视图中展示出来。除了用到Model、View相关的知识外,还会使用到老猿随笔介绍的Excel文件读取相关方法(相关内容请参考《Python学习随笔:使用xlwings读取和操作Execl文件》)。

为了重点突出,在案例代码中没有进行退出处理、没有完整的异常处理,相关文件也是直接在代码中指定,未提供选择界面。

3.2、案例开发步骤

3.2.1、设计UI界面

如图:
在这里插入图片描述
其中table view对象的名字就是tableView。

3.2.2、在界面派生类中通过readExcel读取Excel中的数据存放到Model中

    def readExcel(self):
        excelApp = excelM.App(False, False)  #调用excel模块初始化功能
        excelFile = excelApp.books.open(r'c:	emp期中成绩.xls') #打开excel文件
        excelSheet = excelFile.sheets[0] #获取excel文件中第一个sheet
        rows,cols = excelSheet.used_range.last_cell.row, excelSheet.used_range.last_cell.column #获取数据的行数和列数
        self.excelModel = QStandardItemModel() 
        self.excelModel.setColumnCount(cols)  #设置model的列数

        for row in range(1, rows + 1):
            line = excelSheet.range(row, 1).expand('right').value #从excel中读取第row行整行数据

            if not line: continue
            if row==1:self.showHead(line) #设置表头
            else:self.showRecord(line,row-2) #展示数据行
        self.tableView.setModel(self.excelModel)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

方法showHead展示表头数据,就是将表头数据使用setHeaderData方法来设置,老猿只用了三行代码,具体实现大家可以自己动手。方法showRecord展示一行excel数据,主要使用setItem来创建项并指定存储行和列。
示例代码:

            item = QStandardItem(data)
            self.excelModel.setItem(lineNO, col , item)
  • 1
  • 2

3.2.3、在界面派生类构造方法中调用readExcel

class w_mainWin(ui_tableView.Ui_mainWin,QtWidgets.QWidget):
    def __init__(self):
        super(w_mainWin, self).__init__()
        self.setupUi(self)
        self.readExcel()
  • 1
  • 2
  • 3
  • 4
  • 5

3.3、界面运行截图

在这里插入图片描述

广告

老猿关于PyQt的付费专栏《使用PyQt开发图形界面Python应用》只需要9.9元,该部分与第十五章的内容基本对应,但同样内容在付费专栏上总体来说更详细、案例更多。本节内容对应付费专栏的《第二十章、QTableView与QStandardItemModel开发实战:展示Excel文件内容》。如果有兴趣也愿意支持老猿的读者,欢迎购买付费专栏。

老猿Python,跟老猿学Python!

  • 老猿Python博文目录
  • 专栏:使用PyQt开发图形界面Python应用
  • 老猿Python博客地址
文章知识点与官方知识档案匹配,可进一步学习相关知识
Python入门技能树基本技能数据文件读写333538 人正在系统学习中
老猿Python
微信公众号
专注Python相关语言、图像音视频处理、AI
注:本文转载自blog.csdn.net的LaoYuanPython的文章"https://blog.csdn.net/LaoYuanPython/article/details/104086312"。版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。如有侵权,请联系我们删除。
复制链接
复制链接
相关推荐
发表评论
登录后才能发表评论和回复 注册

/ 登录

评论记录:

未查询到任何数据!
回复评论:

分类栏目

后端 (14832) 前端 (14280) 移动开发 (3760) 编程语言 (3851) Java (3904) Python (3298) 人工智能 (10119) AIGC (2810) 大数据 (3499) 数据库 (3945) 数据结构与算法 (3757) 音视频 (2669) 云原生 (3145) 云平台 (2965) 前沿技术 (2993) 开源 (2160) 小程序 (2860) 运维 (2533) 服务器 (2698) 操作系统 (2325) 硬件开发 (2492) 嵌入式 (2955) 微软技术 (2769) 软件工程 (2056) 测试 (2865) 网络空间安全 (2948) 网络与通信 (2797) 用户体验设计 (2592) 学习和成长 (2593) 搜索 (2744) 开发工具 (7108) 游戏 (2829) HarmonyOS (2935) 区块链 (2782) 数学 (3112) 3C硬件 (2759) 资讯 (2909) Android (4709) iOS (1850) 代码人生 (3043) 阅读 (2841)

热门文章

101
推荐
关于我们 隐私政策 免责声明 联系我们
Copyright © 2020-2024 蚁人论坛 (iYenn.com) All Rights Reserved.
Scroll to Top