Qt 使用 QtXlsx 操作Excel

刚开始尝试了使用:Qt + QAxObject操作Excel,具体可参考这篇博文:《Qt5+QAxObject操作Excel》
但是,采用这种方式就需要平台已经安装Microsoft Excel。后台也会一直存在Excel的进程,需要手动打开任务管理器关闭,并且还会弹出各种烦人的消息框。因此舍弃,采用QtXlsx。

项目主页:http://qtxlsx.debao.me/ 有一些演示
Git地址:https://github.com/dbzhang800/QtXlsxWriter

QtXlsx是一个可以读写Excel文件的库。它不需要Microsoft Excel,可以在Qt5支持的任何平台中使用。该库可用于:

  • 从头开始生成新的.xlsx文件
  • 从现有.xlsx文件中提取数据
  • 编辑现有的.xlsx文件

使用QtXlsx:

1. 使用Xlsx作为Qt5的插件模块

所有文件打包下载:code和activeperl打包下载

  1. 首先安装 ActivePerl_5.16.2.3010812913.msi
  2. 下载down下来的code。https://github.com/VSRonin/QtXlsxWriter (这个是修改了QList的编译不会出错)
  3. 把下载的QtXlsxWriter文件放在一个文件夹下。我的在D:\LeoQt\qt\QtStuProjects\QtXlsxWriter-master5.6\QtXlsxWriter5.6
    开始菜单 –> Qt 5.7.0 –> 5.7 –> MinGW 5…3 (32-bit) –> Qt 5.7 for Desktop , 打开该命令行工具,就能使用 MinGW 和 Qt 库进行编译程序。
    在这里插入图片描述
  4. cd /d D:\LeoQt\qt\QtStuProjects\QtXlsxWriter-master5.6\QtXlsxWriter5.6
    依次执行:
    qmake
    mingw32-make
    mingw32-make install
    在这里插入图片描述
    注意:
    如果down下来的是源文件,则会编译出错,
    在这里插入图片描述
    我们只需要点进入,把QList 改成 QVector ,即先找到文件 src\xlsx\xlsxzipreader.cpp 打开
    如图,将QList 为QVector
    在这里插入图片描述
    并在xlsxzipreader.cpp上增加 #include 即可。

安装OK以后,可以在Qt的安装目录看到以下文件:
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
这样就可以在Pro文件中添加:
QT += xlsx
cpp #include <QtXlsx> int main() { QXlsx::Document xlsx; xlsx.write("A1", "Hello Qt!"); xlsx.saveAs("Test.xlsx"); return 0; }

2. 示例:

  1. 打开已存在的Excel文件,然后,追加写入数据,
QXlsx::Document xlsx_temp("VoltageData.xlsx");
//获取表格的行数、列数
QXlsx::CellRange range;
range = xlsx_temp.dimension();
int rowCount = range.rowCount();
int colCount = range.columnCount();
//下一行写入数据,类似追写入,Excel的
rowCount++;
format.setHorizontalAlignment(Format::AlignLeft);
xlsx_temp.write(rowCount,1,QDATE,format);
xlsx_temp.write(rowCount,2,TIME,format);
format.setHorizontalAlignment(Format::AlignHCenter);
xlsx_temp.write(rowCount,3,strVoltage,format);
xlsx_temp.setColumnWidth(1,10.00);
xlsx_temp.setColumnWidth(2,9.14);
xlsx_temp.saveAs("VoltageData.xlsx");

QtXlsxWriter 说明文档

http://qtxlsx.debao.me/qtxlsx-examples.html
http://qtxlsx.debao.me/qtxlsx-module.html

  • 2
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要利用QtXlsxQt表格小部件导出为Excel文件,需要遵循以下步骤: 1. 首先,需要在Qt项目中添加QtXlsx库,可以使用qmake或手动添加库文件。 2. 在Qt表格小部件中,将数据转换为QXlsx格式。这可以通过循环遍历表格中的和列,并将数据添加到QXlsxWorkbook对象中来完成。 例如,以下代码将Qt表格小部件中的数据转换为QXlsx格式: ```cpp QXlsx::Document xlsx; for(int i=0; i<tableWidget->rowCount(); i++){ for(int j=0; j<tableWidget->columnCount(); j++){ xlsx.write(i+1, j+1, tableWidget->item(i,j)->text()); } } ``` 3. 然后,将生成的QXlsxWorkbook对象保存为Excel文件。可以使用QFileDialog类让用户选择保存位置和文件名。 例如,以下代码将QXlsxWorkbook对象保存为Excel文件: ```cpp QString fileName = QFileDialog::getSaveFileName(this, "Save Excel file", "", "Excel Files (*.xlsx)"); if (!fileName.isEmpty()){ xlsx.saveAs(fileName); } ``` 完整的示例代码如下: ```cpp #include <QFileDialog> #include <QXlsx/Document.h> void MainWindow::on_exportButton_clicked() { QXlsx::Document xlsx; for(int i=0; i<tableWidget->rowCount(); i++){ for(int j=0; j<tableWidget->columnCount(); j++){ xlsx.write(i+1, j+1, tableWidget->item(i,j)->text()); } } QString fileName = QFileDialog::getSaveFileName(this, "Save Excel file", "", "Excel Files (*.xlsx)"); if (!fileName.isEmpty()){ xlsx.saveAs(fileName); } } ``` 注意:在使用QtXlsx库时,需要将以下代码添加到项目的.pro文件中: ``` LIBS += -L/path/to/QtXlsx/lib -lQtXlsx INCLUDEPATH += /path/to/QtXlsx/include ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值