QT使用QtXlsxWriter读取excel文件

QtXlsxWriter是一个用于操作Excel文件的Qt库,支持读写.xlsx格式的文件。

源码引用

在.pro文件中添加:

makefile

复制

makefile 复制代码
include(path/to/QtXlsxWriter/src/xlsx.pri)
 

测试代码

cpp 复制代码
void readExcel(const QString &fileName)
{
   QXlsx::Document xlsx(fileName);

   if (xlsx.sheetNames().isEmpty())// 空文件或打不开
   {
       qDebug() << "open failed or file empty";
       return;
   }

   // 读单个单元格
   QVariant v = xlsx.read("A1");
   qDebug() << "A1 =" << v;

   // 遍历整张表
   for (int row = 2; row <= xlsx.dimension().lastRow(); ++row) {

       qDebug() << QString("%1.%2  %3  %4  %5  %6  ").arg(row).arg(xlsx.read(row, 1).toString()) \
                   .arg(xlsx.read(row, 2).toString()).arg(xlsx.read(row, 3).toString())
                   .arg(xlsx.read(row, 4).toString()).arg(xlsx.read(row, 5).toString());
   }
}

运行发现读取的时候有点问题,会直接把表格里的公式给读出来:

excel内容:

程序读取日志:

sh 复制代码
A1 = QVariant(QString, "序号")
"2.=ROW()-1  0  2      "
"3.=ROW()-1  =B2+2  2      "
"4.=ROW()-1  =B3+2  2      "
"5.=ROW()-1  =B4+2  2      "
"6.=ROW()-1  12  2      "
"7.=ROW()-1  =B6+2  2      "
"8.=ROW()-1  =B7+2  2      "
"9.=ROW()-1  =B8+2  2      "
"10.=ROW()-1  =B9+2  2      "
"11.=ROW()-1  =B10+2  2      "
"12.=ROW()-1  =B11+2  2      "
"13.=ROW()-1  =B12+2  2      "
"14.=ROW()-1  =B13+2  2      "
"15.=ROW()-1  32  2      "
"16.=ROW()-1  =B15+2  2      "
"17.=ROW()-1  =B16+2  2      "
"18.=ROW()-1  =B17+2  2      "
"19.=ROW()-1  =B18+2  2      "
"20.=ROW()-1  =B19+2  2      "

我们需要读取到表格显示值,不用背后的公式,具体修改的代码如下:

如上图中部分代码,就是判断单元表格里如果有公式,则返回公式,这里可以将这部分代码注释掉,直接返回单元格内容,修改后运行结果如下:

sh 复制代码
A1 = QVariant(QString, "序号")
"2.1  0  2      "
"3.2  2  2      "
"4.3  4  2      "
"5.4  6  2      "
"6.5  12  2      "
"7.6  14  2      "
"8.7  16  2      "
"9.8  18  2      "
"10.9  20  2      "
"11.10  22  2      "
"12.11  24  2      "
"13.12  26  2      "
"14.13  28  2      "
"15.14  32  2      "
"16.15  34  2      "
"17.16  36  2      "
"18.17  38  2      "
"19.18  40  2      "
"20.19  42  2      "

这看起来就正常了。

相关推荐
Lhan.zzZ3 小时前
笔记_2026.4.28_004
c++·ide·笔记·qt
MATLAB代码顾问4 小时前
5大智能算法优化标准测试函数对比(Python实现)
开发语言·python
万粉变现经纪人5 小时前
如何解决 pip install llama-cpp-python 报错 未安装 CMake/Ninja 或 CPU 不支持 AVX 问题
开发语言·python·开源·aigc·pip·ai写作·llama
清风明月一壶酒5 小时前
OpenClaw自动处理Word文档全流程
开发语言·c#·word
其实防守也摸鱼5 小时前
CTF密码学综合教学指南--第五章
开发语言·网络·笔记·python·安全·网络安全·密码学
小郑加油6 小时前
python学习Day12:pandas安装与实际运用
开发语言·python·学习
AC赳赳老秦6 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
KuaCpp7 小时前
C++面向对象(速过复习版)
开发语言·c++
wbs_scy7 小时前
Linux线程同步与互斥(三):线程同步深度解析之POSIX 信号量与环形队列生产者消费者模型,从原理到源码彻底吃透
java·开发语言
2zcode7 小时前
基于MATLAB元胞自动机(CA)的AZ80A镁合金动态再结晶(DRX)过程模拟
开发语言·matlab·动态再结晶