分享

QtXlsx使用方法(强大的Excel)

 QomoIT 2018-07-26

今天有幸了解到QtXlsx:http://qtxlsx./

一个强大的对Excel的操作,不仅跨平台,而且不需要安装Excel,读写速度杠杠的。

但是用它的话,还得稍微配置下,查询博客,都是有点缺斤少两的。感觉写的不好。

下来我来说下怎么配置。

首先,下载QtXlsx类,地址:https://github.com/dbzhang800/QtXlsxWriter

这个网页下面也有说明怎么使用。喜欢看原版的请看官方说明大笑

第一个方式:添加到模块

1.首先,下载Perl5地址:https://www./get.html


我当时下载的版本!

根据你Qt版本下载对应版本,现在大部分都用64位的了。(要匹配)

ActivePerl-5.22.1.2201-MSWin32-x64-299574.msi

下载好了之后就一直默认安装即可。

安装好了在打开你的Qt(笔者使用的是Qt5.6.0 msvc版本)和下载的QtXlsx代码。

2.开始编译代码,如果这里你的代码编译报错,不要着急,可能是代码本身的bug。请去git上面查看是否有认问过了,或者直接留言。

笔者使用的时候有个bug,在Qt5.6.0上面报错:关于 "QList" 和 "QVector" 转换问题。

如果有错请自行查看解决方案或者反馈bug  (https://github.com/dbzhang800/QtXlsxWriter/issues)

3.完成第二部,在你编译的目录下回生成lib文件和需要包含的文件(include)还有一个模块pri文件


如果你不了解window下模块添加的方法,请按照下面步骤来。

3.1 : 拷贝上图 include文件下的文件到你的Qt安装目录 C:\Qt\Qt5.6.0\5.6\msvc2015_64\include (直接copy,无需修改任何内容)


3.2 : 拷贝上图lib文件夹下 Qt5Xlsxd.lib   Qt5Xlsx.lib   Qt5Xlsx.prl   Qt5Xlsxd.prl  4个文件到你的Qt的lib下 C:\Qt\Qt5.6.0\5.6\msvc2015_64\lib

3.3 : 拷贝lib文件夹下的  Qt5Xlsx.dll  Qt5Xlsxd.dll 库文件到你的Qt库路径下  C:\Qt\Qt5.6.0\5.6\msvc2015_64\bin

3.4 : 拷贝 mkspecs\modules 文件夹下的qt_lib_xlsx.pri到你的Qt模块下 C:\Qt\Qt5.6.0\5.6\msvc2015_64\mkspecs\modules

此处如果不添加的话,在你的Pro文件内写  QT += xlsx 会不识别此模块


4:好了,现在可以跑例子了。

pro文件里面加上 QT += xlsx

  1. #include <QtXlsx/QtXlsx>
  2. int main()
  3. {
  4. QXlsx::Document xlsx;
  5. xlsx.write("A1", "Hello Qt!");
  6. xlsx.saveAs("Test.xlsx");
  7. return 0;
  8. }

写好代码之后,先qmake下。

然后编译代码,跑代码就OK了。


第二种方法:直接使用代码。

1.当然还是必须要有perl5环境.

2.建立工程,把代码放到工程同级目录


  1. |-- project.pro
  2. |-- ....
  3. |-- 3rdparty\
  4. | |-- qtxlsx\
  5. | |

3. 在项目pro文件里添加

include(3rdparty/qtxlsx/src/xlsx/qtxlsx.pri)
添加之后会重新加载下如下图

4. 在main.cpp添加代码

  1. #include "xlsxdocument.h"
  2. int main()
  3. {
  4. QXlsx::Document xlsx;
  5. xlsx.write("A1", "Hello Qt!");
  6. xlsx.saveAs("Test.xlsx");
  7. return 0;
  8. }

然后同上面一个qmake

编译代码就会生成Excel表格了。

同时注意:不用qmake 的话,使用下面宏。


 

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多