QT实现Excel文件转CSV文件利用QAxObject库

suoniao 2021-01-20
需要:0索币

#include <QDir>

#include <QAxObject>

#include <QScopedPointer>

#include <QDebug>


bool ExcelToCsvFile(const QString &excelFileName, const QString &csvFileName)

{

    if (!QFile::exists(excelFileName))

        return false;


    // 当pApplication析构的时候会将其所有相关的子对象都清理

    QScopedPointer<QAxObject> pApplication(new QAxObject());


    // 设置连接Excel控件,需要在GUI的环境下才能成功

    bool ok = pApplication->setControl("Excel.Application");

    if (!ok)

        return false;


    pApplication->dynamicCall("SetVisible(bool)", false); // false表示不显示窗体

    pApplication->setProperty("DisplayAlerts", false); // false表示不显示(输出)任何警告信息。

    QAxObject *pWorkBooks = pApplication->querySubObject("Workbooks"); // Excel工作薄(对象)

    if (pWorkBooks == 0)

        return false;


    QAxObject *pWorkBook  = pWorkBooks->querySubObject("Open(const QString &)", excelFileName); // 打开一个Excel文件

    if (pWorkBook == 0)

        return false;


    QAxObject *pSheets = pWorkBook->querySubObject("WorkSheets"); // Excel工作表集

    if (pSheets == 0)

        return false;


    QAxObject *pSheet = pSheets->querySubObject("Item(int)", 1); // 得到指定索引的工作表

    if (pSheet == 0)

        return false;


    // 另存为文件, 3: txt文件(空格分隔)| 6: csv文件(逗号分隔)

    pSheet->dynamicCall("SaveAs(const QString&, int)", QDir::toNativeSeparators(csvFileName), 3);


    pApplication->dynamicCall("Quit()");


    return true;

}

回帖
  • 消灭零回复
广告位招租 100元/月 广告位招租 100元/月
相关主题
QT程序闪退错误捕获教程利用DbgHelp 错误调试技术 0
使用CMAKE 配置TagLIb QT5 编译使用TagLib 0
QT实现Excel文件转CSV文件利用QAxObject库 0
QT实现Excel转PDF利用QAxObject库 0
Qt利用QAxWidget读取excel文件 0
Qt条件变量QWaitCondition使用教程 0
Qtcreator cannot open output file debug/suoniao.exe:Permission denied 0
Qt的对象树模型 Qt内存泄漏的原因分析 0
Qt有关QdateTime方法详解 0
Qt基础教程值QByteArray字节容器的使用详解 0
Qt读取打印机设备列表QPrinterInfo类实现 0
Qt利用QFile和QTextStream实现文件的读和写 0
Qt利用map映射读取超大文件 0
Qt高频率读取串口或者写入串口导致运行程序内存占用不断提升 0
QT实现HTTP协议 出现failed to load resource : net :: ERR_CONNECTION_RESET 0
C++相关视频教程合辑 0
C++界面库 Qt嵌入式开发从入门到精通 1604 0
c++就业班13期完整教程 2339 0
就业班C++培训完整版教程移动打车项目安全传输平台项目2504 0
C语言和C++就业班15期培训教程2502 0
相关主题
索鸟快传2.1.0版本发布 0
golang网络数据读取timeout的处理 – 以SetReadDeadline为例 0
索鸟网广告位招租 0
golang利用通道chan实现一个通用的TCP连接池 0
frpc和frps的交互流程详解了解了frp是如何进行TCP代理的 0
golang实现内存池 go语言字节池byte pool实现代码 0
golang网络编程之基于TCP协议实现长连接 golang心跳检测 0
国产光刻机产业链最新核心材料ArF 193nm光刻胶通过用户认证 0
javascript数组相关函数length属性、delete关键字、pop()栈方法、shift() 0
Qt为我们提供了几个可以用于线程Sleep的函数msleep和usleep 0
QT程序闪退错误捕获教程利用DbgHelp 错误调试技术 0
简单快速修改Qtcreator项目工程的名称 0
golang 的interface接口类型断言 0
golang类型断言type的使用 0
golang依赖包管理 mod使用教程 0
golang表单验证库validator 0
如何使用Go语言实现一个简单的异步任务框架呢?生产者消费者模型 0
内网穿透反向代理工具frp实现TCP协议代理源码分析 0
内网穿透反向代理库frp的实现原理分析一 0
什么是socks5?socks5 是一个简单的代理协议 0