教育行業(yè)A股IPO第一股(股票代碼 003032)

全國咨詢/投訴熱線:400-618-4000

C/C++:教你快速搞定Qt下的Json文件使用

更新時(shí)間:2018年01月24日14時(shí)35分 來源:傳智播客 瀏覽次數(shù):

JSON的全稱是”JavaScript Object Notation”,意思是JavaScript對象表示法,它是一種基于文本,獨(dú)立于語言的輕量級數(shù)據(jù)交換格式。JSON 解析器和 JSON 庫支持許多不同的編程語言,目前非常多的編程語言都支持JSON。接下來傳智播客C/C++培訓(xùn)專家為大家介紹一下Qt下的Json的使用。

Json的兩種結(jié)構(gòu)

JSON有兩種表示結(jié)構(gòu),對象和數(shù)組。

l 對象結(jié)構(gòu)以”{”大括號開始,以”}”大括號結(jié)束。中間部分由0或多個(gè)以”,”分隔的”key(關(guān)鍵字)/value(值)”對構(gòu)成,關(guān)鍵字和值之間以”:”分隔,語法結(jié)構(gòu)如代碼。

{

key1:value1,

key2:value2,

...

}

其中關(guān)鍵字是字符串,而值可以是字符串,數(shù)值,true,false,null,對象或數(shù)組。

l 數(shù)組結(jié)構(gòu)以”[”開始,”]”結(jié)束。中間由0或多個(gè)以”,”分隔的值列表組成,語法結(jié)構(gòu)如代碼。

[

true,

123,

“hello,world”

]

數(shù)組中的元素值類型可以相同也可不同。

Json格式的文件在使用的時(shí)候是十分靈活的,其中數(shù)組和對象之間也是可以相互嵌套的,大家可以按照自己的實(shí)際需求來定義成對應(yīng)的格式。例如:

[

{ "firstName":"John" , "lastName":"Doe" },

{ "firstName":"Anna" , "lastName":"Smith" },

{ "firstName":"Peter" , "lastName": "Jones" }

]

Qt5中JSON的生成與解析

Qt5 新增加了處理 JSON 的類,與 XML 類庫類似,均以 QJson 開頭,在 QtCore 模塊中,不需要額外引入其它模塊。Qt5 新增加六個(gè)相關(guān)類:

需要大家著重掌握的類為前四個(gè)。

QJsonDocument

該Json文檔類主要是把json格式的數(shù)據(jù)解析為Qt中的Json文檔對象,所有我們在使用該類之前,需要先把數(shù)據(jù)準(zhǔn)備好:

] 解析Json

1. 使用QFile對象加載指定的Json格式文件

a) QFile file(”D:\\myjson.json”);

b) file.open(QIODevice::ReadWrite);

2. 通過QFile類中的read方法將文件數(shù)據(jù)讀到內(nèi)存

a) QByteArray json = file. readAll();

3. QJsonDocument::fromJson() 可以由 QByteArray 對象構(gòu)造一QJsonDocument 對象,用于我們的讀寫操作

a) QJsonDocument jsDoc;

b) jsDoc = QJsonDocument::fromJson(json.toUtf8());

QJsonObject

] 生成json對象

因?yàn)閖son對象為鍵值對,所以我們可以使用QJsonObject類的insert方法,向該類對象中插入數(shù)據(jù)。

1. 創(chuàng)建空的QJsonObject對象

a) QJsonObject obj;

2. 使用insert方法向空對象中插入數(shù)據(jù)

a) obj.insert(“name”, “Jack”);

b) obj.insert(“age”, 26);

c) obj.insert(“isboy”, true);

] 解析json對象

1. 首先需要先得到一個(gè)QJsonDocument對象,然后判斷該對象是否是一個(gè)json對象,使用isObject()方法

2. 使用QJsonDocument類的object()方法可以將json文檔對象轉(zhuǎn)換為Json對象。

3. 可以通過QJsonObject對象的key值得到其value值,訪問方式為QJsonValue value = obj[key]

4. 使用QJsonValue類的成員方法將value值轉(zhuǎn)換為實(shí)際的數(shù)據(jù)類型。

QJsonDocument parse_doucment;

parse_doucment = QJsonDocument::fromJson(byte_array);

if(parse_doucment.isObject())

{

QJsonObject obj = parse_doucment.object();

if(obj.contains("name"))

{

QJsonValue name_value = obj["name"];

if(name_value.isString())

{

QString name = name_value.toString();

}

}

QJsonArray

] 生成Json

1. 創(chuàng)建Json數(shù)組:

a) QJsonArray json;

2. 使用QJsonArray類的insert方法插入數(shù)據(jù):

a) json.insert(0, QString("Qt"));

b) json.insert(1, QString("version"));

c) json.insert(2, true);

3. 創(chuàng)建Json文檔對象:

a) QJsonDocument document;

4. 將初始化完成的json數(shù)組對象設(shè)置給Json文檔對象

a) document.setArray(json);

5. 將json文檔對象轉(zhuǎn)換為QByteArray對象

a) QByteArray byte_array = document.toJson();

生成的文件格式:["Qt","version",true]

] 解析Json

1. 首先需要先得到一個(gè)QJsonDocument對象,然后判斷該對象是否是一個(gè)json數(shù)組,使用isArray()方法。

2. 使用QJsonDocument類的array()方法可以將json文檔對象轉(zhuǎn)換為Json對象。

3. 可以通過QJsonArray對象遍歷得到其中的每個(gè)value值,訪問方式與遍歷普通數(shù)組的方式相同。

4. 使用QJsonValue類的成員方法將value值轉(zhuǎn)換為實(shí)際的數(shù)據(jù)類型。

QJsonDocument parse_doucment;

parse_doucment = QJsonDocument::fromJson(byte_array);

if(parse_doucment.isArray())

{

QJsonArray array = parse_doucment.array();

int size = array.size();

for(int i=0; i

{

QJsonValue value = array.at(i);

if(value.isString())

{

QString name = value.toString();

}

else if(value.isBool())

{

bool flag = value.toBool();

}

}

}

QJsonValue

在使用json對象或json數(shù)組對象得到對應(yīng)的value之后,該value值并不是最終的數(shù)據(jù)類型而是一個(gè)QJsonValue類型的屬性,我們必須通過該對象判斷該類型的實(shí)際類型,然后在將其轉(zhuǎn)換為對應(yīng)的數(shù)據(jù)類型:

] 類型判斷相關(guān)的成員方法:

n bool isArray() const // 是否為json數(shù)組

n bool isBool() const // 是否為布爾類型

n bool isDouble() const // 是否為浮點(diǎn)類型

n bool isNull() const // 是否為空

n bool isObject() const // 是否為json對象

n bool isString() const // 是否為字符串類型

] 數(shù)據(jù)類型轉(zhuǎn)換相關(guān)成員方法:

n QJsonArray toArray(const QJsonArray &defaultValue) const

n QJsonArray toArray() const // 轉(zhuǎn)為為json數(shù)組

n bool toBool(bool defaultValue = false) const // to布爾類型

n double toDouble(double defaultValue = 0) const

n int toInt(int defaultValue = 0) const

n QJsonObject toObject(const QJsonObject &defaultValue) const

n QJsonObject toObject() const // 轉(zhuǎn)換為json對象

n QString toString(const QString &defaultValue = QString()) const

生成Json

1. 創(chuàng)建JsonObject對象或數(shù)組(再次以對象舉例)

a) QJsonObject json;

2. 往json對象中添加鍵值對

a) json.insert("name", QString("Qt"));

b) json.insert("version", 5);

c) json.insert("windows", true);

3. 創(chuàng)建Json文檔對象

a) QJsonDocument document;

4. 將Json對象或數(shù)組設(shè)置給json文檔對象

a) document.setObject(json); // 數(shù)組:setArray(array)

5. 將文檔對象轉(zhuǎn)換為QByteArray類型的數(shù)據(jù)

a) QByteArray byte_array = document.toJson();

6. 將該數(shù)據(jù)通過QFile對象保存為磁盤文件。

最終格式:{"name": "Qt","version": 5,"windows": true}

好了,今天的的知識點(diǎn),傳智播客C/C++培訓(xùn)專家就給大家分享到這里,希望大家多多練習(xí),祝大家學(xué)習(xí)愉快!

本文版權(quán)歸傳智播客C/C++學(xué)院所有,歡迎轉(zhuǎn)載,轉(zhuǎn)載請注明作者出處。謝謝!
作者:傳智播客C/C++學(xué)院
首發(fā):http://fskzgqt.cn/c/
0 分享到:
和我們在線交談!