Qt excel操作相关

#include <QDebug>
#include <QAxObject>
#include <QStandardPaths>
#include <QFileDialog>
#include <QVariant>
#include <QCoreApplication>

QAxObject *pApplication = NULL;
QAxObject *pWorkBooks = NULL;
QAxObject *pWorkBook = NULL;
QAxObject *pSheets = NULL;
QAxObject *pSheet = NULL;

ExcelImfo excel;

//初始化相关指针
void ExcelImfo::initExcelConfig()
{
    pApplication = new QAxObject;
    pWorkBooks = new QAxObject;
    pWorkBook = new QAxObject;
    pSheets = new QAxObject;
    pSheet = new QAxObject;
}

//新建excel
void ExcelImfo::newExcel(QString &fileName)
{
    pApplication->setControl("Excel.Application");
    pApplication->setProperty("Visible", false);           //不显示任何警告信息
    pApplication->dynamicCall("SetVisible(bool)",false);   //不显示窗体

    pWorkBooks = pApplication->querySubObject("WorkBooks");     //获取工作簿集合

    QFile file(fileName);
    if(!file.exists())
    {
        pWorkBooks->dynamicCall("Add");
        pWorkBook = pApplication->querySubObject("ActiveWorkBook");

        #ifdef EXCEL_WORK_DEBUG
        qDebug()<<"创建新文件"<<"printerData.xls";
        #endif
    }
    else
    {
        pWorkBook = pWorkBooks->querySubObject("Open(const QString &)", fileName);
        #ifdef EXCEL_WORK_DEBUG
        qDebug()<<"打开文件"<<"printerData.xls";
        #endif
    }

    pSheets = pWorkBook->querySubObject("Sheets");
    pSheet = pSheets->querySubObject("Item(int)", 1);

}

//2.增加1个Worksheet
void ExcelImfo::appendSheet(const QString &sheetName,int cnt)
{
    QAxObject *pLastSheet = pSheets->querySubObject("Item(int)", cnt);
    pSheets->querySubObject("Add(QVariant)", pLastSheet->asVariant());
    pSheet = pSheets->querySubObject("Item(int)", cnt);
    pLastSheet->dynamicCall("Move(QVariant)", pSheet->asVariant());
    pSheet->setProperty("Name", sheetName);
}

//3.向Excel单元格中写入数据
void ExcelImfo::setCellValue(int row, int column, const QString &value)
{
    QAxObject *pRange = pSheet->querySubObject("Cells(int,int)", row, column);
    pRange->dynamicCall("Value", value);
}

//5.保存Excel
void ExcelImfo::saveExcel(const QString &fileName)
{
    pWorkBook->dynamicCall("SaveAs(const QString &)",
    QDir::toNativeSeparators(fileName));
}

//6.释放Excel
void  ExcelImfo::freeExcel()
{
    if (pApplication != NULL)
    {
        pApplication->dynamicCall("Quit()");
        delete pApplication;
        pApplication = NULL;
    }
}

转载于:https://www.cnblogs.com/kaixinhuazai/p/8310441.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值