资源简介
#Qt Windows 下快速读写Excel指南
很多人搜如何读写excel都会看到用`QAxObject`来进行操作,很多人试了之后都会发现一个问题,就是慢,非常缓慢!因此很多人得出结论是`QAxObject`读写excel方法不可取,效率低。
后来我曾试过用ODBC等数据库类型的接口进行读写,遇到中文嗝屁不说,超大的excel还是会读取速度慢。
最后,看了一些开源的代码后发现,Windows下读取excel,还是用`QAxObject`最快!没错,就是用`QAxObject`读写最快!!!
大家以后读取excel时(win下),不用考虑别的方法,用`QAxObject`就行,速度杠杠的,慢是你操作有误!下面就说说咋能提高其读取效率。
#读取excel慢的原因
这里不说如何打开或生成excel,着重说说如何快速读取excel。
网上搜到用Qt操作excel的方法,读取都是使用类似下面这种方法进行:
```C
QVariant ExcelBase::read(int row, int col)
{
QVariant ret;
if (this->sheet != NULL && ! this->sheet->isNull())
{
QAxObject* range = this->sheet->querySubObject("Cells(int, int)", row, col);
//ret = range->property("Value");
ret = range->dynamicCall("Value()");
delete range;
}
return ret;
}
```
读取慢的根源就在于`sheet->querySubObject("Cells(int, int)", row, col)`
试想有10000个单元就得调用10000次`querySubObject`,网络上90%的教程都没说这个`querySubObject`产生的`QAxObject*`最好进行手动删除,虽然在它的父级`QAxObject`会管理它的内存,但父级不析构,子对象也不会析构,若调用10000次,就会产生10000个`QAxObject`对象
得益于[QT快速读取数据量很大的Excel文件](http://blog.csdn.net/a1069962325/article/details/49514377)此文,下面总结如何快速读写excel
#快速读取excel文件
原则是一次调用`querySubObject`把所有数据读取到内存中
VBA中可以使用`UsedRange`把所有用到的单元格范围返回,并使用属性`Value`把这些单元格的所有值获取。
这时,获取到的值是一个table,但Qt把它变为一个变量QVariant来储存,其实实际是一个`QList<QList<QVariant> >`,此时要操作里面的内容,需要把这个`QVariant`转换为`QList<QList<QVariant> >`
先看看获取整个单元格的函数示意(这里ExcelBase是一个读写excel的类封装):
```C
QVariant ExcelBase::readAll()
{
QVariant var;
if (this->sheet != NULL && ! this->sheet->isNull())
{
QAxObject *usedRange = this->sheet->querySubObject("UsedRange");
if(NULL == usedRange || usedRange->isNull())
{
return var;
}
var = usedRange->dynamicCall("Value");
delete usedRange;
}
return var;
}
```
代码片段和文件信息
#include “Excelbase.h“
#include
#include
#include
#if defined(Q_OS_WIN)
#include ject>
#endif // Q_OS_WIN
#define TC_FREE(x) {delete x; x=NULL;}
class ExcelbasePrivate
{
Q_DECLARE_PUBLIC(Excelbase)
public:
explicit ExcelbasePrivate(Excelbase* qptr);
~ExcelbasePrivate();
void construct();
void destory();
Excelbase* const q_ptr;
#if defined(Q_OS_WIN)
QAxobject* excel;
QAxobject* books;
QAxobject* book;
QAxobject* sheets;
QAxobject* sheet;
#endif
QString filename;
QString sheetName;
};
ExcelbasePrivate::ExcelbasePrivate(Excelbase *qptr)
: q_ptr(qptr)
#if defined(Q_OS_WIN)
excel(NULL)
books(NULL)
book(NULL)
sheets(NULL)
sheet(NULL)
#endif // Q_OS_WIN
{
}
ExcelbasePrivate::~ExcelbasePrivate()
{
#if defined(Q_OS_WIN)
if(excel)
{
if (!excel->isNull())
{
excel->dynamicCall(“Quit()“);
}
}
TC_FREE
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 18972 2018-01-14 19:43 快速读取excel\pic\01.png
文件 2233 2018-01-14 19:43 快速读取excel\pic\02.png
文件 4298 2018-01-14 19:43 快速读取excel\pic\02_0.png
文件 13072 2018-01-14 19:43 快速读取excel\pic\03.png
文件 8904 2018-01-14 19:43 快速读取excel\readme.md
文件 8973 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\Book1.xlsx
文件 12753 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\Excelba
文件 3649 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\Excelba
文件 654336 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\excelRWByCztr1988.xls
文件 513 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\fastReadExcelInWindows.pro
文件 171 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\main.cpp
文件 2000 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\MainWindow.cpp
文件 543 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\MainWindow.h
文件 1821 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\MainWindow.ui
文件 1850 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\QVariantListListModel.cpp
文件 1111 2018-01-14 19:43 快速读取excel\src\fastReadExcelInWindows\QVariantListListModel.h
目录 0 2018-02-06 10:59 快速读取excel\src\fastReadExcelInWindows
目录 0 2018-02-06 10:59 快速读取excel\pic
目录 0 2018-02-06 10:59 快速读取excel\src
目录 0 2018-02-06 10:59 快速读取excel
----------- --------- ---------- ----- ----
735199 20
相关资源
- Linux内核代码
- INA226电流检测的代码
- 基于STM32F407的AD7616代码
- autosar框架代码
- crc16几种标准校验算法及c语言代码(
- BMS下位机和上位机代码
- robomaster步兵车开源代码
- vxWorks开发:飞控代码源码
- 3KW数字LLC源代码
- 单片机LED流水灯源代码
- 单片机蜂鸣器源代码
- STM32的光立方和灯光秀控制算法源代码
- 三电平NPCSVPWM源代码
- STM32F030 UCOSii 例程代码 mdk
- 基于stm32的平衡车代码
- YDL-TH00温度测试代码
- jsoncpp-0.y.z 代码
- STM32F334同步整流buck代码
- UCOS2源代码(未移植版)
- modbus主机代码(可以用在各种MCU平台
- 51单片机34个经典电路制作,附电路图
- 基于飞思卡尔MC9s单片机的CAN通信代码
- CSA算法MATLAB代码
- windows系统编程源代码第四版
- FTP客户端源代码C语言
- RTSPRTP C++ 源代码
- tftpd32 源代码VC
- rip协议编程及代码实现
- Windows Sockets 编程及UR机器人通信数据
- dvb-TV-机顶盒核心代码
评论
共有 条评论