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