美文网首页Qt学习
Qt处理JSON数据(含数组)并保存至excel表格

Qt处理JSON数据(含数组)并保存至excel表格

作者: 日子总要往前走 | 来源:发表于2018-10-17 02:22 被阅读6次

    今天主要是说一下,今天在项目中解决掉得一个项目需求,需求大概是这样的:qt后台需要处理一份JSON文件,当然了这个是一份标准的JSON文件,然后处理转换存入excel表格。其实这个需求可以分解为三步:

    1. 解析JSON文件中的数据
    2. 将第一步中解析出来的数据保存在数据结构中。
    3. 将第二部中的保存的数据写入excel表格。
      为了能够让大家更方便的学习,我写了一个小的项目,来让大家看的更清楚。具体的项目是做的过程是将下面这一份示例文件,存入excel表格。
    {
        "NBA": [{
            "teamName": "金州勇士队",
            "coach": "史蒂夫-科尔",
            "boss": "乔-拉克布"
        }, {
            "teamName": "洛杉矶快船",
            "coach": "道格-里弗斯",
            "boss": "史蒂夫-鲍尔默"
        }, {
            "teamName": "洛杉矶湖人",
            "coach": "卢克-沃顿",
            "boss": "珍妮-巴斯"
        }, {
            "teamName": "萨克拉门托国王",
            "coach": "戴夫-乔尔格",
            "boss": "维维克-拉纳戴夫"
        }, {
            "teamName": "波特兰开拓者",
            "coach": "特里-斯托茨",
            "boss": "保罗-艾伦"
        }, {
            "teamName": "俄克拉荷马雷霆",
            "coach": "比利-多诺万",
            "boss": "克莱顿-本内特"
        }]
    }
    

    最后保存在excel表格中的样式是这样的:


    excel样式

    下面开始说说实现这个小项目的代码。

    1.解析JSON文件中的数据。

    这一步中,虽然说qt都有现成的API供大家调用,不过我在这一块还是花了不少时间,当然这只是对比第二三步来说,或许是因为我对JSON格式的数据不是很清楚吧,这块的API还是挺绕的。

    bool MainWindow::analysisJson(QString FileName)
    {
        //采用普通方式打开文件,并且存入allDada中,注意这是一种QByteArray格式
        QFile loadFile(FileName);
        if(!loadFile.open(QIODevice::ReadOnly))
        {
            qDebug() << "could't open projects json";
            return false;
        }
        QByteArray allData = loadFile.readAll();
        loadFile.close();
        //开始进行一系列JSON相关的处理
        QJsonParseError json_error;
        QJsonDocument jsonDoc(QJsonDocument::fromJson(allData, &json_error));
        if(json_error.error != QJsonParseError::NoError)
        {
            qDebug() << "json error!";
            return false;
        }
        QJsonObject rootObj = jsonDoc.object();
        //最后数据存入了QJsonObject格式的rootObj中
        if (rootObj.contains("NBA"))
        {
            QJsonValue value = rootObj.value("NBA");
            if (value.isArray())
            {
                QJsonArray array = value.toArray();
                int nSize = array.size();
                for (int i = 0; i < nSize; ++i)
                {
                    NBATeamData temp;
                    temp.teamName = array.at(i).toObject().value("teamName").toString();
                    temp.coachName = array.at(i).toObject().value("coach").toString();
                    temp.BossName = array.at(i).toObject().value("boss").toString();
                    teamData.append(temp);
                }
            }
        }
    }
    
    1. 这部分的代码实现从开始到处理rootObj之前,这其实都是套路,大家只需要照搬过来就可以了。这部分也没有啥需要说的。
    2. 需要注意的就是我处理rootObj的思路。首先分析这个JSON文件,其实很简单,(大家都知道JSON文件说白了就是键值对),这个文件就是一个键值对嵌套了另外一个键值对,然后里边的键值对还用数组表示。这是一个比较难的一个点。
      2.1 首先判断并且根据最外层的键值对的key值,来获取QJsonValue对象。这个对象是存储着值的。
      2.2 然后根据判断2.1中获取到的QJsonValue对象是不是数组结构,是的话,转成QJsonArray.
      2.3 这一步的思路是最重要的,2.2的做法就是为了遍历,然后因为数组中的每一个值,又是三个键值对。想要实现这三个键值对的获取,就必须将之在转化为Object对象,然后再按照处理Object的方法去处理。

    2. 解析出来的数据保存在数据结构中

    下面是我定义的用来储存数据结构的一个类。

    class NBATeamData
    {
    public:
        QString teamName;
        QString coachName;
        QString BossName;
    };
    

    其实我是用QList<NBATeamData> teamData;来保存JSON的解析结果,也就是定义NBATeamData这个类来存单个数据,然后用QList将其封装起来,以方便操作数据。

    3. 写入excel表格

    先直接上代码

    bool MainWindow::addToExcel(QList<NBATeamData> data)
    {
        QString filepath = "D:\\NBA.xls";
        if(!filepath.isEmpty()){
            QAxObject *excel = new QAxObject(this);
            excel->setControl("Excel.Application");//连接Excel控件
            excel->dynamicCall("SetVisible (bool Visible)","false");//不显示窗体
            excel->setProperty("DisplayAlerts", false);//不显示任何警告信息。如果为true那么在关闭是会出现类似“文件已修改,是否保存”的提示
            QAxObject *workbooks = excel->querySubObject("WorkBooks");//获取工作簿集合
    
            workbooks->dynamicCall("Add");//新建一个工作簿
            QAxObject *workbook = excel->querySubObject("ActiveWorkBook");//获取当前工作簿
            QAxObject *worksheets = workbook->querySubObject("Sheets");//获取工作表集合
            QAxObject *worksheet = worksheets->querySubObject("Item(int)",1);//获取工作表集合的工作表1,即sheet1
            QAxObject *cellA,*cellB,*cellC;
    
            //设置标题
            int cellrow=1;
            QString A="A"+QString::number(cellrow);//设置要操作的单元格,如A1
            QString B="B"+QString::number(cellrow);
            QString C="C"+QString::number(cellrow);
    
            //获取单元格
            cellA = worksheet->querySubObject("Range(QVariant, QVariant)",A);
            cellB = worksheet->querySubObject("Range(QVariant, QVariant)",B);
            cellC=worksheet->querySubObject("Range(QVariant, QVariant)",C);
    
            //设置单元格的值
            cellA->dynamicCall("SetValue(const QVariant&)",QVariant("队名"));
            cellB->dynamicCall("SetValue(const QVariant&)",QVariant("教练"));
            cellC->dynamicCall("SetValue(const QVariant&)",QVariant("老板"));
            cellrow++;
    
            int rows=data.size();
            for(int i=0;i<rows;i++){
                QString A="A"+QString::number(cellrow);//设置要操作的单元格,如A1
                QString B="B"+QString::number(cellrow);
                QString C="C"+QString::number(cellrow);
    
                cellA = worksheet->querySubObject("Range(QVariant, QVariant)",A);//获取单元格
                cellB = worksheet->querySubObject("Range(QVariant, QVariant)",B);
                cellC = worksheet->querySubObject("Range(QVariant, QVariant)",C);
    
                cellA->dynamicCall("SetValue(const QVariant&)",QVariant(data.at(i).teamName));//设置单元格的值
                cellB->dynamicCall("SetValue(const QVariant&)",QVariant(data.at(i).coachName));
                cellC->dynamicCall("SetValue(const QVariant&)",QVariant(data.at(i).BossName));
    
                cellrow++;
            }
    
                workbook->dynamicCall("SaveAs(const QString&)",QDir::toNativeSeparators(filepath));//保存至filepath,注意一定要用QDir::toNativeSeparators将路径中的"/"转换为"\",不然一定保存不了。
                workbook->dynamicCall("Close()");//关闭工作簿
                excel->dynamicCall("Quit()");//关闭excel
                delete excel;
                excel=NULL;
            }
            return true;
    }
    
    1. 首先说明一下在QT环境下运行这段代码,要加入如下:其中第一行为头文件,直接加入该文件即可。第二行需要加入.pro文件,加上axcontainer
    #include<QAxObject>
    
    QT       += core gui axcontainer
    

    2.之后的话就是一些流水线的代码,相信你对它是不在话下的

    代码下载地址:https://download.csdn.net/download/qq130106486/10707414
    点击下载代码

    相关文章

      网友评论

        本文标题:Qt处理JSON数据(含数组)并保存至excel表格

        本文链接:https://www.haomeiwen.com/subject/tqxkzftx.html