Qt:QTableWidget
0、说明
QTableWidget类提供了一个基于Item的Table视图,如下图:

Table Widget提供了表格用于显示。Table中的每个Item都是QTableWidgetItem对象。
如果我们想要一个存储我们自己的model的Table,应该用QTableView而不是这个类。
Table Widget构造时,传入Table的行数和列数作为参数:
tableWidget = new QTableWidget(12, 3, this);
不过,也可以先构造一个空Table Widget,之后再为它设置行列数:
tableWidget = new QTableWidget(this);
tableWidget->setRowCount(10);
tableWidget->setColumnCount(5);
Item在Table外构造(没有parent widget),之后通过setItem()把它插入到Table中。
QTableWidgetItem *newItem = new QTableWidgetItem(tr("%1").arg(
(row+1)*(column+1)));
tableWidget->setItem(row, column, newItem);
如果我们想实现排序功能,需要在填充item之后进行,否则会被插入顺序所干扰(可以看setItem()来获取详细信息)。
Table可以设置索引行和索引列。最简单的构造方法是,通过setHorizontalHeaderLabels()和setVerticalHeaderLabels(),传入的参数是索引StringList,List中每一项都是一个索引。更成熟的方法是从已存在的Table Item构造索引Header。例如,我们可以用一个icon和一串文本(aligned text)构造一个特殊索引列。
QTableWidgetItem *cubesHeaderItem = new QTableWidgetItem(tr("Cubes"));
cubesHeaderItem->setIcon(QIcon(QPixmap(":/Images/cubed.png")));
cubesHeaderItem->setTextAlignment(Qt::AlignVCenter);
Table中的行数可以通过rowCount()得知,列数可以通过columnCount()得知。通过clear()来清空Table。
1、模块和加载项
| Header: | #include <QTableWidget> |
| qmake: | QT += widgets |
| Inherits: | QTableView |
2、构造
| QTableWidget(int rows, int columns, QWidget *parent = nullptr) | 构造一个指定行列数的空Table |
| QTableWidget(QWidget *parent = nullptr) | 构造一个空Table |
4、成员字段
| int | columnCount | 列数 |
| int | rowCount | 行数 |
6、成员方法
返回值类型 |
方法 |
说明 |
| QWidget * | cellWidget(int row, int column) | 返回一个QWidget展示给定行列的cell |
| void | closePersistentEditor(QTableWidgetItem *item) | 关闭当前Item编辑器 |
| int | column(const QTableWidgetItem *item) | 返回参数Item的所在列 |
| int | columnCount() | 一共多少列 |
| int | currentColumn() | 当前Item所在列 |
| QTableWidgetItem * | currentItem() | 当前Item |
| int | currentRow() | 当前Item所在行 |
| void | editItem(QTableWidgetItem *item) | 如果Item是可编辑的,那么开始编辑该Item |
| QList<QTableWidgetItem *> | findItems(QString text, Qt::MatchFlags flags) | 查找Item |
| QTableWidgetItem * | horizontalHeaderItem(int column) | 返回某一列的行Header Item |
| bool | isPersistentEditorOpen(QTableWidgetItem *item) | Item编辑器是否开启 |
| QTableWidgetItem * | item(int row, int column) | 提取指向指定行、列的Item的指针 |
| QTableWidgetItem * |
itemAt(QPoint point) itemAt(int ax, int ay) |
提取Widget坐标系中指定坐标的Item的指针 |
| QTableWidgetItem * | itemPrototype() | |
| void | openPersistentEditor(QTableWidgetItem *item) | 为给定Item打开编辑器,编辑器在完成编辑后会一直开启 |
| void | removeCellWidget(int row, int column) | 移除指定行列cell的Widget |
| int | row(const QTableWidgetItem *item) | 返回Item的Row |
| int | rowCount() | 行数 |
| QList<QTableWidgetItem *> | selectedItems() | 返回一个List *,其中有所有选中的Items |
| QList<QTableWidgetSelectionRange> | selectedRanges() | |
| void | setCellWidget(int row, int column, QWidget *widget) |
在指定Cell处展示Widget,如果先后在同一个Cell设置了不同的Widget,那么后一个Widget会覆盖前一个 setCellWidget(row, column, new QLineEdit); |
| setColumnCount(int columns) | 重定义列数,如果小于当前列数,则会丢弃多余列 | |
| setCurrentCell(int row, int column) | 设置当前Cell为指定的Cell | |
| setCurrentItem(QTableWidgetItem *item) | 设置当前Item为指定的Item | |
| setHorizontalHeaderItem(int column, QTableWidgetItem *item) | 设置column列的索引Item为item | |
| setHorizontalHeaderLabels(QStringList labels) | 设置索引行标签 | |
| setItem(int row, int column, QTableWidgetItem *item) | 设置指定行列的Item为item | |
| setItemPrototype(const QTableWidgetItem *item) | ||
| setRangeSelected(QTableWidgetSelectionRange range, bool select) | ||
| setRowCount(int rows) | 重定义行数,多出的行会被丢弃 | |
| setVerticalHeaderItem(int row, QTableWidgetItem *item) | 设置row行的索引Item为item | |
| setVerticalHeaderLabels(QStringList labels) | 设置索引列标签 | |
| sortItems(int column, Qt::SortOrder order = Qt::AscendingOrder) | 对Table所有行按column列和order规则进行排序 | |
| QTableWidgetItem * | takeHorizontalHeaderItem(int column) | 提取指定column的索引行的Item |
| QTableWidgetItem * | takeItem(int row, int column) | 提取指定行、列的Item |
| QTableWidgetItem * | takeVerticalHeaderItem(int row) | 提取指定row的索引列的Item |
| QTableWidgetItem * | verticalHeaderItem(int row) | 提取指定row的索引列的Item |
| int | visualColumn(int logicalColumn) | 返回给定logicalColumn的可视列 |
| QRect | visualItemRect(const QTableWidgetItem *item) | 返回只有指定Item的矩形视图 |
| int | visualRow(int logicalRow) | 返回给定logicalRow的可视行 |
7、信号
信号 |
说明 |
| cellActivated(int row, int column) | 当指定行列的cell被激活时发送该信号 |
| cellChanged(int row, int column) | 当指定行列的cell中的数据被激活时发送该信号 |
| cellClicked(int row, int column) | 每当Table中的一个cell被点击时发送该信号,信号中的参数是被点击的cell的行、列 |
| cellDoubleClicked(int row, int column) | 每当Table中的一个cell被双击时发送该信号,信号中的参数是被双击的cell的行、列 |
| cellEntered(int row, int column) | 每当鼠标光标进入一个cell时发送该信号,信号中的参数是cell的行、列 |
| cellPressed(int row, int column) | 每当Table中的一个cell被按时,信号中的参数是被按的cell的行、列(可能是键盘?该信号不确定) |
| currentCellChanged(int currentRow, int currentColumn, int previousRow, int previousColumn) | 每当Table中的当前聚焦的cell改变时,参数分别标明改变前后的cell的行、列 |
| currentItemChanged(QTableWidgetItem *current, QTableWidgetItem *previous) | 每当Table中的当前的Item改变时,参数分别标明改变前后的Item |
| itemActivated(QTableWidgetItem *item) | 每当Table中参数指明的Item激活(选中)时,发送该信号 |
| itemChanged(QTableWidgetItem *item) | 每当Table中参数指明的Item改变时,发送该信号 |
| itemClicked(QTableWidgetItem *item) | 每当Table中参数指明的Item被单击时,发送该信号 |
| itemDoubleClicked(QTableWidgetItem *item) | 每当Table中参数指明的Item被双击时,发送该信号 |
| itemEntered(QTableWidgetItem *item) | 每当鼠标焦点进入Table中的某个Item时,发送该信号,参数指明这个Item |
| itemPressed(QTableWidgetItem *item) | 每当Table中的某个Item被按时,发送该信号,参数指明这个Item |
| itemSelectionChanged() | 每当选中的Item改变时发送该信号 |
8、槽
槽 |
说明 |
| clear() | 移除Table中的所有Item,包括索引 |
| clearContents() | 移除Table中的所有Item,不包括索引。 |
| insertColumn(int column) | 在column列插入一个空列 |
| insertRow(int row) | 在row行插入一个空行 |
| removeColumn(int column) | 移除column列 |
| removeRow(int row) | 移除row行 |
| scrollToItem(const QTableWidgetItem *item, QAbstractItemView::ScrollHint hint = EnsureVisible) | 上下滚动视图,以保证item始终可见 |
Qt:QTableWidget的更多相关文章
- PyQt(Python+Qt)学习随笔:QTableWidget中表格各列平均分配宽度的两种方法
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 在QTableWidget表格部件中,如果需要实现表格中各列要占满部件中的可用空间,同时实现各列平分 ...
- PyQt(Python+Qt)学习随笔:QTableWidget的构造方法
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 QTableWidget有2个构造方法: QTableWidget(QWidget parent = ...
- Qt中 QTableWidget用法总结
转自--> http://edsionte.com/techblog/archives/3014 http://hi.baidu.com/fightiger/item/693aaa0f0f87d ...
- PyQt学习随笔:QTableWidget项sizeHint的作用以及与QHeadView的sectionResizeMode、ResizeToContents的关系
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 在学习QTableWidgetItem的sizeHint()方法时,Qt自带材料中介绍sizeHin ...
- Qt:禁止qDebug的输出
Qt:禁止qDebug的输出 在工程的.pro文件里加上以下编译批令即可: DEFINES += QT_NO_DEBUG_OUTPUT
- Qt:使用自定义的字体
Qt:使用自定义的字体 1. 下载字体文件 2. 加载字体文件 3. 使用字体 QFontDatabase::addApplicationFont("XENOTRON.TTF" ...
- PyQt学习随笔:QTableWidget的selectedRanges、setRangeSelected访问选中矩形范围的方法
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 在QTableWidget对项的操作支持选中多个项的情况下,可以通过方法selectedRanges ...
- Qt:QJsonObject
0.说明 QJsonObject在逻辑上就是一个Map或Dict!记住这一点对理解它的方法.说明很有帮助. QJsonObject类封装了JSON Object. JSON Object是一个Key- ...
- Qt:QJsonValue
0.说明 QJsonValue类用于操作JSON中的各种数据. JSON是用于存储结构化数据的格式,JSON中的数据可以是六种类型: 基本类型 存储类型 bool QJsonValue::Bool d ...
随机推荐
- Nginx怎么处理请求的?
nginx接收一个请求后,首先由listen和server_name指令匹配server模块,再匹配server模块里的 location,location就是实际地址. server { # 第 ...
- jenkins自动化pipline的ci/cd流水线
pipeline { agent any tools { //工具必须预先在jenkins中预配置 maven 'mvn' jdk 'jdk' } stages { stage('Env') { st ...
- nginx配置支持websocket
前两天折腾了下socketio,部署完发现通过nginx代理之后前端的socket无法和后端通信了,于是暴查一通,最后解决问题: location / { proxy_pass http://127. ...
- Kubeadm部署K8S(kubernetes)集群(测试、学习环境)-单主双从
1. kubernetes介绍 1.1 kubernetes简介 kubernetes的本质是一组服务器集群,它可以在集群的每个节点上运行特定的程序,来对节点中的容器进行管理.目的是实现资源管理的自动 ...
- Python中列表操作函数append的浅拷贝问题
L=int(input())#L位数N=int(input())#N进制row=[]list1=[]for i in range(1,N): row.append(1)list1.append(row ...
- Rock Pi开发笔记(一):Rock Pi系列arm产品方案快速落地方案介绍
前言 开发RK3399等相关的项目和产品做评估,最近发现Rock Pi4是一个很好的评估版,价格合适,能满足评估的开发,像树莓派一样留出来引脚接口,是很好的快速落地arm系列产品和项目的较好方案选 ...
- JQuery扩展方法实现Form表单与Json互相转换
1.把表单转换出json对象 //把表单转换出json对象 $.fn.toJson = function () { var self = this, json = {}, push_counters ...
- UITabBarController管理原则
- Nginx http重定向https
SSL证书申请的腾讯的,配置好证书后,直接监听80端口转发443就ok了 转发语句:rewrite ^/(.*) https://$server_name:443$request_uri? perma ...
- 解决sublime代码不提示的问题
如果想让sublime在你输入标签的过程中给你提示,需要按要求开启以下功能. 1.开启代码自动提示功能