大家好,又见面了,我是你们的朋友全栈君。
以故事方式来学习如何使用Qt接口来操作JSON数据。
JSON三兄弟
老大哥QJsonValue
- 主要用于封装JSON值,类似于QVariant。
它能够存储以下值:
类型 | QJsonValue类型 |
---|---|
bool | QJsonValue::Bool |
double | QJsonValue::Double |
string | QJsonValue::String |
array | QJsonValue::Array |
object | QJsonValue::Object |
null | QJsonValue::Null |
- 与QVariant互转
QJsonValue fromVariant(const QVariant &variant)
QVariant QJsonValue::toVariant() const
- 可以与QJsonObject,QJsonArray互转
QJsonValue::QJsonValue(const QJsonArray &a)
QJsonObject QJsonValue::toObject() const
QJsonValue::QJsonValue(const QJsonObject &o)
QJsonArray QJsonValue::toArray() const
二哥QJsonObject
- 负责封装JSON对象,是键/值对列表,其中键是惟一的字符串,值由QJsonValue表示。
- QJsonObject与QVariantMap可以互相转换。
- 接口与QMap相似,都具有size()、insert()和remove()等操作,还可以使用标准C++迭代器模式对其内容进行迭代。
- 直接构造使用:
QJsonObject jsonObject
{
{
"key1", 1},
{
"key2", 6.6},
{
"key3", "Hello world"},
{
"array", QJsonArray({
1, 2, 3})}
};
- 类似于QVariantMap操作:
QJsonObject jsonObject;
jsonObject["key1"] = 1;
jsonObject["key2"] = 6.6;
jsonObject.insert("key3", "Hello world");
jsonObject["array"] = QJsonArray({
1, 2, 3});
- 与QVariantMap互相转换
QJsonObject fromVariantMap(const QVariantMap &map)
QVariantMap QJsonObject::toVariantMap() const
- 还可以与QVariantHash互相转换,操作类似QVariantMap转换。
三弟QJsonArray
-
负责封装JSON数组,JSON数组是一个值列表,接口与QVariantList类似,QJsonArray与QVariantList可以互相转换。
-
QJsonList操作于QList相似,都具有size()、insert()和removeAt()等操作,还可以使用标准的C++迭代器模式对其内容进行迭代。
-
直接赋值使用:
QJsonArray jsonArray = {
1, 6.6, QString("Hello world") };
- 接口操作使用:
QJsonArray jsonArray;
jsonArray.append(1);
jsonArray.append(6.6);
jsonArray.insert(2, "Hello world");
- 与QVariantList互相转换:
QJsonArray fromVariantList(const QVariantList &list)
QVariantList QJsonArray::toVariantList() const
JSON管家
一天,三兄弟玩得甚欢,管家有些烦恼,三兄弟年龄不小了,还整天捣蛋,苦不堪言,是时候帮它们解决人生大事了,让他们得老婆来管这三兄弟。管家暗暗窃喜。老夫赶紧将他们的资料(数据)转换为字符串发给对面Web端的大户人家先。
管家拿出QJsonDocument工具转换他们三兄弟的资料。
QJsonDocument(const QJsonObject &object)
QJsonDocument(const QJsonArray &array)
QByteArray toJson() const
分别将QJsonObject与QJsonArray转换为QByteArray。
QByteArray byteArray1 = QJsonDocument(jsonObject).toJson();
QByteArray byteArray2 = QJsonDocument(jsonArray).toJson();
管家看了看,拿到资料了,不知道资料是否正确,还是要确保一下就使用isNull
接口验证:
bool QJsonDocument::isNull() const // 如果返回为true则JSON数据解析不正确或为空。
焦急的管家等了几天,对面Web端怎么会没有答复的。正在焦虑走来走去,是不是资料不够好?还是发送出去格式不好看,看来要给他们弄弄格式,于是就找来了生成字符串的toJson
来解决。
toJson
面对焦急得管家自然也不敢怠慢,立马给出解决方案。
QByteArray toJson(QJsonDocument::JsonFormat format) const
- JsonFormat::Indented(缩进型)
{
"key1": 1,
"key2": 6.6
}
- JsonFormat::Compact(紧凑型)
{
"key1":1,"key2":6.6}
管家修改了一下格式发出去,很快就收到对面妹子发送过来资料数据了,要快快解析看看。
管家先将QByteArray数据转换为QJsonDocument对象,然后再转换为QJsonObject或QJsonArray即可。
QJsonDocument fromJson(const QByteArray &json, QJsonParseError *error = nullptr)
管家看了看,老夫还是有点效果的。
QJsonDocument jsonDoc = QJsonDocument::fromJson("{\"address\":\"村口客栈见\",\"note\":\"带点吃的\"}");
JSON背锅者
管家又接收到了一封信,可是解析不出来,正在头皮发麻着思考到底是那一步出错了。
突然跳出一个人QJsonParseError
说:管家这锅我来背,我帮你找出问题,但我又一个小小得要求,就是你也给我介绍介绍。
管家无奈只好答应。
QJsonParseError jsonError;
QJsonDocument jsonDoc = QJsonDocument::fromJson("{\"note\":\"二哥有点帅\"}", &jsonError);
qDebug()<<jsonError.errorString();
小子你可以啊,原来fromJson
还有这操作。
后续
管家将此事告诉他们三兄弟,如获珍宝一样。老大哥还说,看来我单身30年就要终结了。二哥则表示要在妹子面前露一手,三弟也不甘示弱赶紧去问老爹准备点钱。
后续他们三兄弟结局如何?,是否抱得美人归?请关注下篇Qt之JSON教程-实战篇
。
- 文章首发于微信公众号:Qt君
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/126528.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...