当前位置: 首页 > news >正文

QtC++与QTableView详解

介绍

QTableView 是 Qt 框架中用于显示表格数据的视图控件,它是 QAbstractItemView 类的子类。QTableView 通常与 QStandardItemModel 或者自定义的数据模型一起使用,用于展示二维表格型数据。以下是对 QTableView 的详细讲解和在 Qt 中的作用:

QTableView 的作用:

  1. 显示表格数据: 主要用于显示二维表格形式的数据,其中数据可以是来自文件、数据库查询结果或其他来源。

  2. 编辑表格数据: 提供了对表格数据的编辑功能,用户可以直接在表格中进行数据的修改和输入。

  3. 支持排序和过滤: 具有内置的排序和过滤功能,可以通过设置相关属性来启用或禁用。

  4. 支持多种选择模式: 可以配置为单选、多选、行选择、列选择等不同的选择模式,以适应不同的应用场景。

  5. 自定义外观和交互: 允许通过自定义委托 (QAbstractItemDelegate) 或者子类化 QTableView 来实现自定义单元格的外观和交互。

  6. 数据排序和过滤: 支持用户对表格数据进行排序和过滤,提高数据的查看和管理效率。

  7. 支持拖放操作: 允许用户通过拖放操作在表格中移动、复制或重新排列数据。

QTableView 常用方法和信号:

以下是一些常用的方法和信号,可用于控制和响应 QTableView 的行为:

  • setModel(QAbstractItemModel *model): 设置与 QTableView 关联的数据模型。
  • setSelectionMode(QAbstractItemView::SelectionMode mode): 设置选择模式,可以是单选、多选或无选择。
  • setSortingEnabled(bool enable): 启用或禁用排序。
  • setEditTriggers(QAbstractItemView::EditTriggers triggers): 设置编辑触发器,控制何时启用编辑功能。
  • resizeColumnsToContents(): 调整列宽以适应内容。
  • resizeRowsToContents(): 调整行高以适应内容。
  • horizontalHeader(): 返回水平表头对象,可用于对表头进行定制。
  • verticalHeader(): 返回垂直表头对象,可用于对表头进行定制。
  • clicked(const QModelIndex &index): 单击某个单元格时触发的信号。
  • doubleClicked(const QModelIndex &index): 双击某个单元格时触发的信号。

示例应用场景:

  1. 数据库查询结果: 在数据库工具中,QTableView 可以显示数据库查询结果,用户可以直接在表格中编辑和管理数据。

  2. 报表生成: 用于生成和展示报表数据,支持用户查看和编辑报表中的数据。

  3. 数据分析工具: 在数据分析工具中,QTableView 可以显示和分析大量的数据,支持排序和过滤功能。

  4. 任务调度管理: 在任务调度管理系统中,QTableView 可以显示任务列表,支持用户对任务进行编辑和排序。

  5. 图形化配置界面: 用于创建图形化配置界面,用户可以通过表格形式配置软件参数和选项。

注意事项:

  • 使用 QTableView 时,通常需要一个合适的数据模型,例如 QStandardItemModelQSqlTableModel 或者自定义的模型类。

  • 当表格数据较大时,考虑启用排序和过滤以提高用户体验。

  • 对于复杂的单元格外观和交互需求,可以通过自定义委托或者子类化 QTableView 来实现。

结论:

QTableView 是一个功能强大的 Qt 控件,适用于显示和编辑表格形式的数据。它提供了丰富的功能和灵活性,使得开发者能够轻松创建各种表格界面,并以直观的方式展示和编辑二维表格型数据。

示例

#include <QApplication>
#include <QTableView>
#include <QStandardItemModel>
#include <QStandardItem>
#include <QHeaderView>
#include <QDebug>int main(int argc, char *argv[]) {QApplication app(argc, argv);// 示例1: 创建简单的 QTableViewQTableView simpleTableView;QStandardItemModel simpleModel;// 添加表头simpleModel.setHorizontalHeaderLabels({"Name", "Age", "City"});// 添加数据QList<QStandardItem*> rowData;rowData << new QStandardItem("John") << new QStandardItem("25") << new QStandardItem("New York");simpleModel.appendRow(rowData);rowData.clear();rowData << new QStandardItem("Alice") << new QStandardItem("30") << new QStandardItem("London");simpleModel.appendRow(rowData);simpleTableView.setModel(&simpleModel);simpleTableView.show();// 示例2: 启用编辑功能QTableView editableTableView;QStandardItemModel editableModel;editableModel.setHorizontalHeaderLabels({"Task", "Status"});QList<QStandardItem*> taskData;taskData << new QStandardItem("Task 1") << new QStandardItem("Incomplete");editableModel.appendRow(taskData);taskData.clear();taskData << new QStandardItem("Task 2") << new QStandardItem("Complete");editableModel.appendRow(taskData);editableTableView.setModel(&editableModel);editableTableView.setEditTriggers(QAbstractItemView::DoubleClicked | QAbstractItemView::EditKeyPressed);editableTableView.show();// 示例3: 使用自定义数据模型QTableView customModelTableView;CustomTableModel customModel;customModelTableView.setModel(&customModel);customModelTableView.show();// 示例4: 自定义表头QTableView customHeaderTableView;QStandardItemModel customHeaderModel;customHeaderModel.setHorizontalHeaderLabels({"Name", "Age", "City"});taskData.clear();taskData << new QStandardItem("Bob") << new QStandardItem("22") << new QStandardItem("Paris");customHeaderModel.appendRow(taskData);taskData.clear();taskData << new QStandardItem("Eva") << new QStandardItem("28") << new QStandardItem("Berlin");customHeaderModel.appendRow(taskData);customHeaderTableView.setModel(&customHeaderModel);customHeaderTableView.horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);customHeaderTableView.show();return app.exec();
}
// 示例6: 自定义单元格的外观和交互
class CustomDelegate : public QStyledItemDelegate {
public:QWidget* createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const override {if (index.column() == 1) {// 创建一个自定义的编辑器,例如一个带有下拉框的编辑器QComboBox *editor = new QComboBox(parent);editor->addItem("Incomplete");editor->addItem("Complete");return editor;}return QStyledItemDelegate::createEditor(parent, option, index);}void setEditorData(QWidget *editor, const QModelIndex &index) const override {if (index.column() == 1) {// 将数据设置到编辑器上QComboBox *comboEditor = qobject_cast<QComboBox*>(editor);if (comboEditor) {comboEditor->setCurrentText(index.data().toString());}} else {QStyledItemDelegate::setEditorData(editor, index);}}void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const override {if (index.column() == 1) {// 从编辑器中获取数据并设置到模型QComboBox *comboEditor = qobject_cast<QComboBox*>(editor);if (comboEditor) {model->setData(index, comboEditor->currentText());}} else {QStyledItemDelegate::setModelData(editor, model, index);}}
};// 示例7: 使用自定义排序模型
class CustomSortModel : public QSortFilterProxyModel {
public:bool lessThan(const QModelIndex &left, const QModelIndex &right) const override {// 自定义排序规则,例如按照第二列数字排序QVariant leftData = sourceModel()->data(left);QVariant rightData = sourceModel()->data(right);return leftData.toInt() < rightData.toInt();}
};// 示例8: 支持拖放操作
void setupDragDrop(QTableView &tableView) {tableView.setDragEnabled(true);tableView.setAcceptDrops(true);tableView.setDropIndicatorShown(true);
}// 示例9: 实现表格合并
void mergeCells(QTableView &tableView) {// 使用 setSpan 方法合并单元格tableView.model()->setData(tableView.model()->index(0, 0), 1, Qt::UserRole); // 设置 UserRole 表示是合并的起始单元格tableView.setSpan(0, 0, 2, 1); // 合并两行
}// 示例10: 添加右键菜单
void setupContextMenu(QTableView &tableView) {tableView.setContextMenuPolicy(Qt::CustomContextMenu);QObject::connect(&tableView, &QTableView::customContextMenuRequested, [&tableView](const QPoint &pos) {QMenu contextMenu;QAction *action = contextMenu.addAction("Custom Action");contextMenu.exec(tableView.mapToGlobal(pos));});
}// 示例11: 定制表格的样式
void setCustomStyle(QTableView &tableView) {tableView.setStyleSheet("QTableView { background-color: lightgray; selection-background-color: blue; }");
}// 示例12: 实现动态更新
void setupDynamicUpdate(QTableView &tableView) {QTimer *timer = new QTimer(&tableView);QObject::connect(timer, &QTimer::timeout, [&tableView]() {// 模拟数据动态更新QStandardItemModel *model = qobject_cast<QStandardItemModel*>(tableView.model());if (model) {model->setData(model->index(0, 1), QTime::currentTime().toString("hh:mm:ss"));}});timer->start(1000); // 每秒更新一次
}// 示例13: 表格的导出和导入
void exportImportData(QTableView &tableView) {// 导出数据tableView.model()->setData(tableView.model()->index(1, 0), "Exported Data");// 导入数据QString importedData = tableView.model()->data(tableView.model()->index(1, 0)).toString();qDebug() << "Imported Data:" << importedData;
}// 示例14: 使用数据库模型
void setupDatabaseModel(QTableView &tableView) {QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");db.setDatabaseName(":memory:"); // 在内存中创建数据库if (db.open()) {QSqlQuery query;query.exec("CREATE TABLE tasks (name TEXT, status TEXT)");query.exec("INSERT INTO tasks VALUES ('Task 1', 'Incomplete')");query.exec("INSERT INTO tasks VALUES ('Task 2', 'Complete')");QSqlTableModel *databaseModel = new QSqlTableModel(&tableView, db);databaseModel->setTable("tasks");databaseModel->select();tableView.setModel(databaseModel);} else {qDebug() << "Failed to open database";}
}// 示例15: 添加过滤器
void setupFilter(QTableView &tableView) {QSortFilterProxyModel *filterModel = new QSortFilterProxyModel(&tableView);filterModel->setSourceModel(tableView.model());filterModel->setFilterFixedString("Incomplete");tableView.setModel(filterModel);
}// 示例16: 实现表格中的图表
void setupChartInTable(QTableView &tableView) {QStandardItemModel *model = new QStandardItemModel(3, 3, &tableView);for (int row = 0; row < 3; ++row) {for (int col = 0; col < 3; ++col) {QStandardItem *item = new QStandardItem(QString::number(row * 3 + col));model->setItem(row, col, item);}}// 创建图表并将其嵌套到表格中QChart *chart = new QChart();chart->setTitle("Chart in Table");chart->legend()->hide();QChartView *chartView = new QChartView(chart);chartView->setRenderHint(QPainter::Antialiasing);// 将图表视图嵌套到表格中tableView.setIndexWidget(model->index(0, 2), chartView);
}// 示例17: 设置列宽和行高
void setupColumnRowSize(QTableView &tableView) {tableView.setColumnWidth(0, 150);tableView.setRowHeight(0, 30);
}// 示例18: 处理大量数据
void handleLargeData(QTableView &tableView) {// 使用虚拟滚动优化大量数据的显示tableView.setVerticalScrollMode(QAbstractItemView::ScrollPerPixel);tableView.setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOn);tableView.horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);// 生成大量数据QStandardItemModel *largeDataModel = new QStandardItemModel(1000, 10, &tableView);for (int row = 0; row < 1000; ++row) {for (int col = 0; col < 10; ++col) {QStandardItem *item = new QStandardItem(QString("(%1, %2)").arg(row).arg(col));largeDataModel->setItem(row, col, item);}}tableView.setModel(largeDataModel);
}// 示例19: 实现自定义的交互功能
void setupCustomInteraction(QTableView &tableView) {QObject::connect(&tableView, &QTableView::clicked, [&tableView](const QModelIndex &index) {qDebug() << "Custom Clicked: " << index.data();});
}

相关文章:

QtC++与QTableView详解

介绍 QTableView 是 Qt 框架中用于显示表格数据的视图控件&#xff0c;它是 QAbstractItemView 类的子类。QTableView 通常与 QStandardItemModel 或者自定义的数据模型一起使用&#xff0c;用于展示二维表格型数据。以下是对 QTableView 的详细讲解和在 Qt 中的作用&#xff…...

HG/T 6002-2022 氟树脂粉末涂料检测

氟树脂粉末涂料是指以三氟氯乙烯-乙烯基醚、四氟乙烯-乙烯基醚等交联型氟树脂或聚偏二氟乙烯PVDF树脂为主要成膜物质&#xff0c;可加入颜料、填料、助剂、固化剂等制成的粉末涂料&#xff0c;主要用于铝型材、幕墙金属板、家电等表面的装饰和保护。 HG/T 6002-2022 氟树脂粉末…...

【java】idea可以连接但看不到database相关的files

问题 idea右侧有database工具栏&#xff0c;但点击没有在recent files看到数据库相关文件 问题排查 点击 help-> show log in explorer查看日志 发现显示 2023-11-13 10:28:09,694 [1244376] INFO - #c.i.c.ComponentStoreImpl - Saving appDebuggerSettings took 22…...

信驰达科技加入车联网联盟(CCC),推进数字钥匙发展与应用

CCC)的会员。 图 1 深圳信驰达正式成为车联网联盟(CCC)会员 车联网联盟(CCC)是一个跨行业组织&#xff0c;致力于推动智能手机与汽车连接解决方案的技术发展。CCC涵盖了全球汽车和智能手机行业的大部分企业&#xff0c;拥有150多家成员公司。CCC成员公司包括智能手机和汽车制造…...

p9 Eureka-搭建eureka服务

1.在user-service项目引入spring-cloud-starter-netflix-eureka-client的依赖 <dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId></depen…...

阶段七-Day01-SpringMVC

一、Sping MVC的介绍 1. 使用Front(前端)设计模式改写代码 1.1 目前我们的写法 目前我们所写的项目&#xff0c;持久层、业务层的类都放入到Spring容器之中了。他们之间需要注入非常方便&#xff0c;只需要通过Autowired注解即可。 但是由于Servlet整个生命周期都是被Tomca…...

Python---集合中的交集 、并集 | 与差集 - 特性

用 & 来求两个集合的交集&#xff1a;-----键盘上的7上的符号&#xff0c;shift 7 同时按 用 | 来求两个集合的并集&#xff1a; -----键盘上的7上的符号&#xff0c;shift 同时按&#xff08;就是enter键上面那个|\ &#xff09; 用 - 来求两个集合的差集&#xff…...

C++调用lua脚本,包括全局函数绑定、类绑定,十分钟快速掌握

系列文章目录 lua调用C/C的函数&#xff0c;十分钟快速掌握 C调用lua脚本&#xff0c;包括全局函数绑定、类绑定&#xff0c;十分钟快速掌握 系列文章目录摘要环境使用步骤码代码自定义函数多返回值变长参数 自定义类test_sol2.lua内容 程序输出 摘要 在这个快节奏的技术博客…...

快乐数[简单]

优质博文&#xff1a;IT-BLOG-CN 一、题目 编写一个算法来判断一个数n是不是快乐数。「快乐数」定义为&#xff1a;对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为1&#xff0c;也可能是无限循环但始终变不到1。如…...

Spring源码阅读-ClassPathXmlApplicationContext

第一步&#xff1a;new一个ClassPathXmlApplicationContext对象 ClassPathXmlApplicationContext xmlContext new ClassPathXmlApplicationContext("mylearn.xml"); 第二步&#xff1a;调用构造方法 public ClassPathXmlApplicationContext(String configLocatio…...

考研分享第2期 | 中央财经大学管理科学跨考北大软微金融科技406分经验分享

一、个人信息 本科院校&#xff1a;中央财经大学 管理科学与工程学院 管理科学专业 上岸院校&#xff1a;北京大学 软件与微电子学院 金融科技专业硕士 考试科目&#xff1a; 初试&#xff1a;思想政治理论 英语一 数学二 经济学综合 面试考察范围广&#xff0c;包括英语自…...

Linux安装java jdk配置环境 方便查询

编辑/etc/profile文件&#xff1a; vim /etc/profile 在文件尾部添加如下配置&#xff1a; export JAVA_HOME/usr/local/jdk1.8.0_161/ export CLASSPATH.: J A V A H O M E / j r e / l i b / r t . j a r : JAVA_HOME/jre/lib/rt.jar: JAVAH​OME/jre/lib/rt.jar:JAVA_HOME/l…...

惊群效应之Nginx处理

文章目录 惊群概述Nginx 解决方案之锁的设计锁结构体原子锁创建原子锁获取原子锁实现原子锁释放 Nginx 解决方案之惊群效应总结&#xff1a; 惊群概述 在说nginx前&#xff0c;先来看看什么是“惊群”&#xff1f;简单说来&#xff0c;多线程/多进程&#xff08;linux下线程进…...

SpringBoot整合Ldap--超详细方法讲解

LADP概述 LDAP&#xff08;轻量目录访问协议&#xff09;是一种用于访问和维护分布式目录信息服务的协议。目录服务是一种存储和检索信息的服务&#xff0c;通常用于存储组织内的用户信息、组织结构、网络设备等数据。LDAP是一种轻量级的协议&#xff0c;设计用于在目录中进行查…...

【工程实践】Docker使用记录

前言 服务上线经常需要将服务搬到指定的服务器上&#xff0c;经常需要用到docker&#xff0c;记录工作中使用过dcoker指令。 1.写Dockerfile 1.1 全新镜像 FROM nvidia/cuda:11.7.1-devel-ubuntu22.04ENV WORKDIR/data/Qwen-14B-Chat WORKDIR $WORKDIR ADD . $WORKDIR/RUN ap…...

FreeSwitch安装视频

文章目录 序言Centos7安装FreeSwitch-1.6 序言 学习资料来源《FreeSWITCH权威指南》-作者杜金房这本书。我是2022年6月毕业的&#xff0c;偶然的机会接触到FreeSWITCH&#xff0c;FreeSWITCH纯属个人爱好&#xff0c;进行笔记整理。也一直希望有机会可以参与FreeSWITCH相关工作…...

SpringBoot3+Vue3+Mysql+Element Plus完成数据库存储blob类型图片,前端渲染后端传来的base64类型图片

前言 如果你的前后端分离项目采用SpringBoot3Vue3Element Plus&#xff0c;且在没有OSS&#xff08;对象存储&#xff09;的情况下&#xff0c;使用mysql读写图片&#xff08;可能不限于图片&#xff0c;待测试&#xff09;。 耗时三天&#xff0c;在踩了无数雷后&#xff0c…...

攻略 | 参与Moonbeam Ignite Ecosystem Tour

Moonbeam联合Moonwell和Beamswap一起举办社区链上活动&#xff0c;旨在让社区用户通过任务来探索Moonbeam、Moonwell、Beamswap平台。在了解如何使用的同时&#xff0c;参与任务挑战还有机会分得 1700 USDC 奖池 &#x1f381; 的奖励&#xff01;我已经完成全部任务&#xff0…...

【python自动化】Playwright基础教程(七)Keyboard键盘

【python自动化】Playwright基础教程(七)Keyboard键盘 playwright模拟键盘操作 键盘事件提供了用于管理虚拟键盘的API&#xff0c;高级API是keyboard.type()&#xff0c;它使用的是原始字符再页面上生成对应的keydown 、 keypress / input 和 keyup 事件。 模拟真实键盘操作进行…...

Java读取文件内容写入新文件

要实现读写文件这个过程我们需要导入以下的包 import java.io.BufferedReader; import java.io.BufferedWriter;BufferedReader 用于逐行读取源文件的内容&#xff0c;BufferedWriter 用于逐行写入目标文件。 下面以示例了解如何操作&#xff1a; import java.io.BufferedRe…...

KubeSphere 容器平台高可用:环境搭建与可视化操作指南

Linux_k8s篇 欢迎来到Linux的世界&#xff0c;看笔记好好学多敲多打&#xff0c;每个人都是大神&#xff01; 题目&#xff1a;KubeSphere 容器平台高可用&#xff1a;环境搭建与可视化操作指南 版本号: 1.0,0 作者: 老王要学习 日期: 2025.06.05 适用环境: Ubuntu22 文档说…...

微信小程序之bind和catch

这两个呢&#xff0c;都是绑定事件用的&#xff0c;具体使用有些小区别。 官方文档&#xff1a; 事件冒泡处理不同 bind&#xff1a;绑定的事件会向上冒泡&#xff0c;即触发当前组件的事件后&#xff0c;还会继续触发父组件的相同事件。例如&#xff0c;有一个子视图绑定了b…...

脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)

一、数据处理与分析实战 &#xff08;一&#xff09;实时滤波与参数调整 基础滤波操作 60Hz 工频滤波&#xff1a;勾选界面右侧 “60Hz” 复选框&#xff0c;可有效抑制电网干扰&#xff08;适用于北美地区&#xff0c;欧洲用户可调整为 50Hz&#xff09;。 平滑处理&…...

React Native 导航系统实战(React Navigation)

导航系统实战&#xff08;React Navigation&#xff09; React Navigation 是 React Native 应用中最常用的导航库之一&#xff0c;它提供了多种导航模式&#xff0c;如堆栈导航&#xff08;Stack Navigator&#xff09;、标签导航&#xff08;Tab Navigator&#xff09;和抽屉…...

AtCoder 第409​场初级竞赛 A~E题解

A Conflict 【题目链接】 原题链接&#xff1a;A - Conflict 【考点】 枚举 【题目大意】 找到是否有两人都想要的物品。 【解析】 遍历两端字符串&#xff0c;只有在同时为 o 时输出 Yes 并结束程序&#xff0c;否则输出 No。 【难度】 GESP三级 【代码参考】 #i…...

大数据零基础学习day1之环境准备和大数据初步理解

学习大数据会使用到多台Linux服务器。 一、环境准备 1、VMware 基于VMware构建Linux虚拟机 是大数据从业者或者IT从业者的必备技能之一也是成本低廉的方案 所以VMware虚拟机方案是必须要学习的。 &#xff08;1&#xff09;设置网关 打开VMware虚拟机&#xff0c;点击编辑…...

电脑插入多块移动硬盘后经常出现卡顿和蓝屏

当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时&#xff0c;可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案&#xff1a; 1. 检查电源供电问题 问题原因&#xff1a;多块移动硬盘同时运行可能导致USB接口供电不足&#x…...

ETLCloud可能遇到的问题有哪些?常见坑位解析

数据集成平台ETLCloud&#xff0c;主要用于支持数据的抽取&#xff08;Extract&#xff09;、转换&#xff08;Transform&#xff09;和加载&#xff08;Load&#xff09;过程。提供了一个简洁直观的界面&#xff0c;以便用户可以在不同的数据源之间轻松地进行数据迁移和转换。…...

GitHub 趋势日报 (2025年06月08日)

&#x1f4ca; 由 TrendForge 系统生成 | &#x1f310; https://trendforge.devlive.org/ &#x1f310; 本日报中的项目描述已自动翻译为中文 &#x1f4c8; 今日获星趋势图 今日获星趋势图 884 cognee 566 dify 414 HumanSystemOptimization 414 omni-tools 321 note-gen …...

三体问题详解

从物理学角度&#xff0c;三体问题之所以不稳定&#xff0c;是因为三个天体在万有引力作用下相互作用&#xff0c;形成一个非线性耦合系统。我们可以从牛顿经典力学出发&#xff0c;列出具体的运动方程&#xff0c;并说明为何这个系统本质上是混沌的&#xff0c;无法得到一般解…...