Qt篇——QTableWidget保存表格数据到Excel文件中,读Excel内容到QTableWidget

表格和excel例子如下图所示: 

一、QTableWidget保存表格数据到Excel文件中

代码如下:

(pro文件中添加QT += axcontainer)

#include <QAxObject>void MainWindow::saveTableToExcel() {QDateTime current_date_time =QDateTime::currentDateTime();QString excelName = "data_" + current_date_time.toString("yyyy-MM-dd_hh-mm-ss");QString filePath = QFileDialog::getSaveFileName(this, "Save Data", excelName, "Microsoft Excel 2013(*.xlsx)");int row = ui->originDataTable->rowCount();int col = ui->originDataTable->columnCount();QAxObject* excel = new QAxObject(this);//excel->setControl("ket.Application");//wpsexcel->setControl("Excel.Application"); //Excelexcel->dynamicCall("SetVisible(bool Visible)", false);excel->setProperty("DisplayAlerts", false);QAxObject* workbooks = excel->querySubObject("WorkBooks");workbooks->dynamicCall("Add");QAxObject* workbook = excel->querySubObject("ActiveWorkBook");QAxObject* worksheets = workbook->querySubObject("Sheets");QAxObject* worksheet = worksheets->querySubObject("Item(int)", 1);for (int i = 0; i < row; i++) {for (int j = 0; j < col; j++) {QAxObject* Range = worksheet->querySubObject("Cells(int,int)", i + 1, j + 1);Range->dynamicCall("SetValue(const QString &)", ui->originDataTable->item(i, j)->text());}}workbook->dynamicCall("SaveAs(const QString &)", QDir::toNativeSeparators(filePath));if (excel != NULL) {excel->dynamicCall("Quit()");delete excel;excel = NULL;}QMessageBox::information(this, QStringLiteral("提示"), "保存成功");
}

二、读Excel文件内容到QTableWidget表格中

#include <QAxObject>void MainWindow::saveTableToExcel() {QString strFile = QFileDialog::getOpenFileName(this,QStringLiteral("选择Excel文件"),"","Exel file(*.xls *.xlsx)");if (strFile.isEmpty()){return;}QAxObject excel("Excel.Application");excel.setProperty("Visible", false);QAxObject *work_books = excel.querySubObject("WorkBooks");//打开指定文件work_books->dynamicCall("Open (const QString&)", strFile);QAxObject *work_book = excel.querySubObject("ActiveWorkBook");QString ExcelName;static int row_count = 0, column_count = 0;QAxObject *work_sheet = work_book->querySubObject("Sheets(int)", 1);QAxObject *used_range = work_sheet->querySubObject("UsedRange");QAxObject *rows = used_range->querySubObject("Rows");row_count = rows->property("Count").toInt();QAxObject *column = used_range->querySubObject("Columns");column_count = column->property("Count").toInt();//这里先清空QTableWidget表格数据ui->originDataTable->clearContents();ui->setRowCount(0);for (int i = 1; i <= row_count; i++) {QStringList dataList;for (int j = 1; j <= column_count;j++) {QAxObject *range = work_sheet->querySubObject("Cells(int,int)",i,j); //获取cell的值QString strVal = range->dynamicCall("Value2()").toString();dataList << strVal;}int row = ui->originDataTable->rowCount();ui->originDataTable->insertRow(row);for (int col = 0; col < dataList.size(); ++col) {QTableWidgetItem *pItem = new QTableWidgetItem(dataList[col]);ui->originDataTable->setItem(row, col, pItem);}}work_book->dynamicCall("Close(Boolean)", false);  //关闭文件excel.dynamicCall("Quit(void)");  //退出
}

总结:

QAxObject读取excel较为方便,不必使用第三方库;缺点是读取excel文件时非常慢,一个内容很少的excel文件读取都需要几秒钟。 用第三方库读取效率会高一些,我用的是xlsx的库,需要的可以在评论区留下自己的邮箱,我将在有空时回复并发到邮箱。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/495835.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络:路由协议

路由协议简介 路由协议是计算机网络中不可或缺的一部分&#xff0c;它们负责确定数据包从源地址到目的地址的最佳路径。想象一下&#xff0c;如果你是一个数据包&#xff0c;路由协议就像是地图或导航工具&#xff0c;指导你如何到达目的地。 目录 路由协议简介 工作原理简化…

代码随想录算法训练营day24

题目&#xff1a;77. 组合 参考链接&#xff1a;代码随想录 回溯法理论基础 回溯三部曲&#xff1a;回溯函数模板返回值以及参数、回溯函数终止条件、回溯搜索的遍历过程。 模板框架&#xff1a; void backtracking(参数) {if (终止条件) {存放结果;return;}for (选择&…

36.云原生之SpringCloud+k8s实践

云原生专栏大纲 文章目录 SpringCloudk8s介绍spring-cloud-kubernetes服务发现配置管理负载均衡选主 spring-cloud-bookinfo案例构建项目环境配置namespace部署与验证productpagegatewaybookinfo-admindetailsratingsreviewsreviews-v1reviews-v2 总结 SpringCloudk8s介绍 ht…

数据结构与算法(数组,栈,队列,链表,哈希表,搜索算法,排序算法,查找算法,策略算法,递归算法,二叉搜索树BST,动态规划算法)

文章目录 1 课程介绍1.1 前置知识1.2 为什么要学习算法1.3 大厂面试常见数据结构题目(基础)1.4 数据结构和算法的关系 2 数据结构2.1 数据结构概述2.1.1 数据结构是什么2.1.2 数据结构分类2.1.2.1 线性结构2.1.2.2 非线性结构2.1.2.3 小总结 2.1.3 数据结构范围 2.2 数组Array2…

Android Activity启动模式

文章目录 Android Activity启动模式概述四种启动模式Intent标记二者区别 Android Activity启动模式 概述 Activity 的管理方式是任务栈。栈是先进后出的结构。 四种启动模式 启动模式说明适用场景standard标准模式默认模式&#xff0c;每次启动Activity都会创建一个新的Act…

WPF的DataGrid自动生成中文列头

直接将一个对象集合绑定到DataGrid上面&#xff0c;设置自动生成列AutoGenerateColumns"True"&#xff0c;DataGrid会自动根据对象类的属性生成对应的列 示例类对象&#xff1a; public class DataModel{public int Id { get; set; }public string Name { get; set;…

六、防御保护---防火墙内容安全篇

六、防御保护---防火墙内容安全篇 一、IAE&#xff08;Intelligent Awareness Engine&#xff09;引擎二、深度检测技术(DFI和DPI&#xff09;2.1 DPI -- 深度包检测技术2.1.1 基于“特征字”的检测技术2.1.2 基于应用网关的检测技术2.1.3 基于行为模式的检测技术 2.2 DFI -- 深…

基于时域有限差分法的FDTD的计算电磁学算法-YEE网格下的更新公式推导

基于时域有限差分法的FDTD的计算电磁学算法&#xff08;含Matlab代码&#xff09;-YEE网格下的更新公式推导 参考书籍&#xff1a;The finite-difference time-domain method for electromagnetics with MATLAB simulations&#xff08;国内翻译版本&#xff1a;MATLAB模拟的电…

小程序框架(概念、工作原理、发展及应用)

引言 移动应用的普及使得用户对于轻量级、即时可用的应用程序需求越来越迫切。在这个背景下&#xff0c;小程序应运而生&#xff0c;成为一种无需下载安装、即点即用的应用形式&#xff0c;为用户提供了更便捷的体验。小程序的快速发展离不开强大的开发支持&#xff0c;而小程…

SpringMVC 学习(十)之异常处理

目录 1 异常处理介绍 2 通过 SimpleMappingExceptionResolver 实现 3 通过接口 HandlerExceptionResolver 实现 4 通过 ExceptionHandler 注解实现&#xff08;推荐&#xff09; 1 异常处理介绍 在 SpringMVC中&#xff0c;异常处理器&#xff08;Exceptio…

QT摄像头采集

主界面为显示框&#xff0c;两个下拉框&#xff0c;一个是所有相机&#xff0c;一个是相机支持的分辨率 系统根据UI界面自动生成的部分不再描述&#xff0c;以下为其他部分源码 widget.h #include <QWidget> #include <QMouseEvent> class QCamera; class QCamer…

电脑上不了网怎么办 无法上网及右下角网路出现感叹号的解决方法

网络故障(network failure)是指由于硬件的问题、软件的漏洞、病毒的侵入等引起网络无法提供正常服务或降低服务质量的状态。随着生活水平的提高,电脑逐渐普遍,经常上网的同学难免遇到上网故障,下面小编总结一下常见的网络故障 网络故障(network failure)是指由于硬件的问题、…