Qt利用QJson實現(xiàn)解析數(shù)組的示例詳解
前言
現(xiàn)在有這樣一個json結(jié)構(gòu),需要使用QJson來解析,結(jié)構(gòu)如下:
"code": "0001", "descrip": "文本描述1詳細描述", "id": "1", "title": "文本1標題", "type": 0, "paths": ["E:/3.json", "F:/11.txt"] }, { "code": "0002", "descrip": "文本描述2詳細描述", "id": "2", "title": "文本2標題", "type": 0, "paths": ["E:/AndroidSetting.png", "E:/build.png", "F:/C++工程.png", "F:/build完成.png"] }, { "code": "00040003", "descrip": "文本", "id": "3", "title": "文本3標題", "type": 0, "paths": ["F:/native-lib文件分析.png", "F:/編輯工程.png"] }]
直接是一組json數(shù)組,連個關(guān)鍵字也沒有,這樣的數(shù)據(jù)該如何解析呢?
假設(shè)這些數(shù)據(jù)是存儲在std::string串中,那么對以上字符串進行解析~
第一步:進行數(shù)據(jù)轉(zhuǎn)換
將字符串解析成QJson識別的格式,第一步少不了QJsonDocument::fromJson
函數(shù)的轉(zhuǎn)換,在QJsonDocument類中,該函數(shù)的定義如下:
static QJsonDocument fromJson(const QByteArray &json, QJsonParseError *error = nullptr);
參數(shù)是QByteArray類型。
第一步要做的工作就是如何將std::string轉(zhuǎn)成QByteArray類型?
QString qsJson = QString::fromLocal8Bit(sJson.c_str()); QByteArray qsArray = qsJson.toUtf8().data();
在這里,需要注意的是,QString轉(zhuǎn)成QByteArray時,一定是使用toUtf8
而不是toLocal8Bit
,否則在將字符串解析成QJsonDocument時,無法解析成功!
第二步:將字符串轉(zhuǎn)成QJsonDocument格式
QJsonParseError stError; QJsonDocument jsonDoc = QJsonDocument::fromJson(qsJson.toUtf8().data(), &stError); if (stError.error != QJsonParseError::NoError) { QString qsError = stError.errorString(); } if (jsonDoc.isNull()) { return false; //json結(jié)構(gòu)解析失敗 }
代碼講解:
為了防止在解析中出現(xiàn)錯誤而不知道是哪種原因時,就用到了QJsonParseError
類,一旦發(fā)現(xiàn)字符串解析失敗,就可以獲取錯誤原因,方便我們在程序開發(fā)時進行查找。
第三步:解析json數(shù)據(jù)
首先,將QJsonDocument轉(zhuǎn)成QJsonArray結(jié)構(gòu)
QJsonArray jsArrays = jsonDoc.array();
其次,遍歷數(shù)據(jù)。與普通的STL的遍歷方式一致,采用for循環(huán)方式,拿去下標下對應的數(shù)據(jù)
for(int i = 0; i < jsArrays.count(); i++) { QJsonValue valueArrayObject = jsArrays.at(i); if (valueArrayObject.type() != QJsonValue::Object) { continue; } QJsonObject jsArrayValue = valueArrayObject.toObject(); QJsonValue jsCode = jsArrayValue.value("code"); QString qsCode = jsCode.toString(); }
代碼解析:
上述代碼流程:
1:讀取數(shù)組下標數(shù)據(jù)
2:判斷當前第i個數(shù)據(jù)的類型是不是json類型,此時,不是,不需要后續(xù)操作
3:類型轉(zhuǎn)換
4:實際的json數(shù)據(jù)解析
上述只是用"code"做示例,其它的參數(shù)也如同code參數(shù)的解析方式一致,就不再過多說明了。但是需要注意,在讀取下標、判斷類型、類型轉(zhuǎn)換這三步驟操作一定是要做的。
對于"paths"中僅有字符串的結(jié)構(gòu),該如何解析呢?
此時,就省略了第二步、第三步操作,直接將下標對應的json結(jié)構(gòu)解析就可以了
QJsonValue valuePathObject = jsUrlArray.at(m); //獲取數(shù)組下標數(shù)據(jù) QString qsPath = valuePathObject.toString();
到此這篇關(guān)于Qt利用QJson實現(xiàn)解析數(shù)組的示例詳解的文章就介紹到這了,更多相關(guān)Qt QJson解析數(shù)組內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用簡潔的C語言代碼解決跳臺階問題與約瑟夫環(huán)問題
這篇文章主要介紹了利用簡潔的C語言代碼解決跳臺階問題與約瑟夫環(huán)問題的方法,跳臺階問題與約瑟夫環(huán)問題是常見的基礎(chǔ)算法題目,需要的朋友可以參考下2016-02-02正確理解C++的構(gòu)造函數(shù)和析構(gòu)函數(shù)
在C++的學習中,可以把類當作一個模具,類實例化出來的對象就是根據(jù)這個模具所產(chǎn)生的實體,對象看作是自己創(chuàng)建的一個新的數(shù)據(jù)類型。本文主要介紹了類對象通過拷貝函數(shù)進行初始化,分析類對象的內(nèi)存模型,以及通過this指針實現(xiàn)更復雜的功能。最后介紹了析構(gòu)函數(shù)的基礎(chǔ)知識2021-06-06C++實現(xiàn)LeetCode(95.獨一無二的二叉搜索樹之二)
這篇文章主要介紹了C++實現(xiàn)LeetCode(95.獨一無二的二叉搜索樹之二),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07