在实际工作中,我们需要qt后台需要处理一份JSON文件,并且还要将这份文件存到excel表格,对于一些新手来说,这是一个难题,那qtjson中包含数据数组怎么存excel表格?下面我们用实例讲解一下。
其实这个需求可以分解为三步:
解析JSON文件中的数据
将第一步中解析出来的数据保存在数据结构中。
将第二部中的保存的数据写入excel表格。
为了能够让大家更方便的学习,我写了一个小的项目,来让大家看的更清楚。具体的项目是做的过程是将下面这一份示例文件,存入excel表格。
{ "NBA": [ { "teamName": "金州勇士队" , "coach": "史蒂夫-科尔" , "boss": "乔-拉克布" } , { "teamName": "洛杉矶快船" , "coach": "道格-里弗斯" , "boss": "史蒂夫-鲍尔默" } , { "teamName": "洛杉矶湖人" , "coach": "卢克-沃顿" , "boss": "珍妮-巴斯" } , { "teamName": "萨克拉门托国王" , "coach": "戴夫-乔尔格" , "boss": "维维克-拉纳戴夫" } , { "teamName": "波特兰开拓者" , "coach": "特里-斯托茨" , "boss": "保罗-艾伦" } , { "teamName": "俄克拉荷马雷霆" , "coach": "比利-多诺万" , "boss": "克莱顿-本内特" }] }
下面开始说说实现这个小项目的代码。
#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); } } } }
这部分的代码实现从开始到处理rootObj之前,这其实都是套路,大家只需要照搬过来就可以了。这部分也没有啥需要说的。
需要注意的就是我处理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 teamData;来保存JSON的解析结果,也就是定义NBATeamData这个类来存单个数据,然后用QList将其封装起来,以方便操作数据。
3. 写入excel表格
先直接上代码
bool MainWindow::addToExcel(QListdata) { 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++) { < p = "" > 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; }
qtjson中包含数据数组存excel表格的整体步骤来说还是有些复杂的,不过我们只要清楚的知道每一步的含义,多操作几遍就会熟练啦!最后大家如果想要了解更多json相关知识,敬请关注奇Q工具网。
推荐阅读: