热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用QtXlsx读写Excel文件

一、获取QtXlsxhttps:github.comdbzhang800QtXlsxWriter二、编译1、下载并解压,得到如下文件2、用QtCreater打开

一、获取QtXlsx

https://github.com/dbzhang800/QtXlsxWriter

二、编译

1、下载并解压,得到如下文件

2、用QtCreater打开,仅构建src项目即可

3、构建报错,将QList改为QVector即可,需要添加#include

4、编译成功后得到如下目录

5、拷贝bin目录下文件到Qt安装目录中,注意所要使用得编译器类型,我的C:\Qt\Qt5.12.4\5.12.4\msvc2017_64\bin

->

6、拷贝include目录到C:\Qt\Qt5.12.4\5.12.4\msvc2017_64\include

->

注意,QtXlsx中得部分头文件需要替换为E:\download\QtXlsxWriter-master\src\xlsx中得响应文件

7、拷贝下图中选中的lib中得文件到C:\Qt\Qt5.12.4\5.12.4\msvc2017_64\lib

8、拷贝下面3个文件到C:\Qt\Qt5.12.4\5.12.4\msvc2017_64\mkspecs\modules

三、使用

1、.pro文件中添加QT+= xlsx

2、头文件包含:

#include "QtXlsx/QtXlsx"

3、写

QXlsx::Document xlsx;
xlsx.write("A1", "Hello Qt!");
xlsx.saveAs("Test.xlsx");/QXlsx::Document xlsx(path);for (int i = 0; i columnCount(); i++) {xlsx.write(1, i + 1, tbl->horizontalHeaderItem(i)->text());}for (int r = 0; r rowCount(); r++) {for (int c = 0; c columnCount(); c++) {QString item_text = tbl->item(r, c)->text();xlsx.write(r + 2, c + 1, item_text);}}QMessageBox::information(0, tr("Export"), xlsx.save() ? tr("Save sessuced!") : tr("Save failed!"));

4、读

QString path &#61; QFileDialog::getOpenFileName(m_wgt, "file");if(file_path.isEmpty()) return;if(!file_path.contains(".xlsx")) {QMessageBox::warning(m_wgt, tr("Warning"), tr("File selection error, place select again!"));return;}QXlsx::Document xlsx(path);QXlsx::Workbook *workBook &#61; xlsx.workbook();QXlsx::Worksheet *workSheet &#61; static_cast(workBook->sheet(0));//第一个标签页QDebug() <sheet(0)->sheetName();QString value;for (int i &#61; 0; i <&#61; workSheet->dimension().rowCount(); i&#43;&#43;){for (int j &#61; 1; j <&#61; workSheet->dimension().columnCount(); j&#43;&#43;){QXlsx::Cell *cell &#61; workSheet->cellAt(i, j);value &#61; cell->value().toString();QDebug() <

 


推荐阅读
  • 本文详细解析了使用C++实现的键盘输入记录程序的源代码,该程序在Windows应用程序开发中具有很高的实用价值。键盘记录功能不仅在远程控制软件中广泛应用,还为开发者提供了强大的调试和监控工具。通过具体实例,本文深入探讨了C++键盘记录程序的设计与实现,适合需要相关技术的开发者参考。 ... [详细]
  • PHP预处理常量详解:如何定义与使用常量 ... [详细]
  • 本文介绍了如何利用Shell脚本高效地部署MHA(MySQL High Availability)高可用集群。通过详细的脚本编写和配置示例,展示了自动化部署过程中的关键步骤和注意事项。该方法不仅简化了集群的部署流程,还提高了系统的稳定性和可用性。 ... [详细]
  • 在本地环境中调试远程服务器上的网站代码执行问题,可以通过以下步骤实现:首先,在本地安装 Visual Studio 并配置远程调试工具。接着,确保服务器和本地机器之间的网络连接畅通,并正确设置防火墙规则以允许调试流量。最后,使用 Visual Studio 的远程调试功能连接到服务器,进行代码调试。这种方法不仅提高了开发效率,还减少了在服务器上直接操作的风险。 ... [详细]
  • 如何使用 `org.apache.poi.openxml4j.opc.PackagePart` 类中的 `loadRelationships()` 方法及其代码示例详解 ... [详细]
  • 本文详细解析了 Android 系统启动过程中的核心文件 `init.c`,探讨了其在系统初始化阶段的关键作用。通过对 `init.c` 的源代码进行深入分析,揭示了其如何管理进程、解析配置文件以及执行系统启动脚本。此外,文章还介绍了 `init` 进程的生命周期及其与内核的交互方式,为开发者提供了深入了解 Android 启动机制的宝贵资料。 ... [详细]
  • 在ElasticStack日志监控系统中,Logstash编码插件自5.0版本起进行了重大改进。插件被独立拆分为gem包,每个插件可以单独进行更新和维护,无需依赖Logstash的整体升级。这不仅提高了系统的灵活性和可维护性,还简化了插件的管理和部署过程。本文将详细介绍这些编码插件的功能、配置方法,并通过实际生产环境中的应用案例,展示其在日志处理和监控中的高效性和可靠性。 ... [详细]
  • 深入剖析Java中SimpleDateFormat在多线程环境下的潜在风险与解决方案
    深入剖析Java中SimpleDateFormat在多线程环境下的潜在风险与解决方案 ... [详细]
  • 在Android平台中,播放音频的采样率通常固定为44.1kHz,而录音的采样率则固定为8kHz。为了确保音频设备的正常工作,底层驱动必须预先设定这些固定的采样率。当上层应用提供的采样率与这些预设值不匹配时,需要通过重采样(resample)技术来调整采样率,以保证音频数据的正确处理和传输。本文将详细探讨FFMpeg在音频处理中的基础理论及重采样技术的应用。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 如何撰写适应变化的高效代码:策略与实践
    编写高质量且适应变化的代码是每位程序员的追求。优质代码的关键在于其可维护性和可扩展性。本文将从面向对象编程的角度出发,探讨实现这一目标的具体策略与实践方法,帮助开发者提升代码效率和灵活性。 ... [详细]
  • 本文详细介绍了批处理技术的基本概念及其在实际应用中的重要性。首先,对简单的批处理内部命令进行了概述,重点讲解了Echo命令的功能,包括如何打开或关闭回显功能以及显示消息。如果没有指定任何参数,Echo命令会显示当前的回显设置。此外,文章还探讨了批处理技术在自动化任务执行、系统管理等领域的广泛应用,为读者提供了丰富的实践案例和技术指导。 ... [详细]
  • 利用 fopen、fwrite、fread、fseek 和 fclose 实现文件中整型数据的读写操作 ... [详细]
  • 使用Maven JAR插件将单个或多个文件及其依赖项合并为一个可引用的JAR包
    本文介绍了如何利用Maven中的maven-assembly-plugin插件将单个或多个Java文件及其依赖项打包成一个可引用的JAR文件。首先,需要创建一个新的Maven项目,并将待打包的Java文件复制到该项目中。通过配置maven-assembly-plugin,可以实现将所有文件及其依赖项合并为一个独立的JAR包,方便在其他项目中引用和使用。此外,该方法还支持自定义装配描述符,以满足不同场景下的需求。 ... [详细]
  • 通过利用代码自动生成技术,旨在减轻软件开发的复杂性,缩短项目周期,减少冗余代码的编写,从而显著提升开发效率。该方法不仅能够降低开发人员的工作强度,还能确保代码的一致性和质量。 ... [详细]
author-avatar
mobiledu2502931473
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有