Qt之JSON生成与解析

 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。它基于JavaScript(Standard ECMA-262 3rd Edition - December 1999)的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C、C++、C#、Java、JavaScript、Perl、Python等)。这些特性使JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成。

常用的Json库
  • JsonCpp
      JsonCpp是一个C++用来处理JSON数据的开发包。
      网址: http://jsoncpp.sourceforge.net/.
  • cJSON
    cJSON 一个超轻巧,携带方便,单文件,简单的可以作为 ANSI-C 标准的 JSON 解析器。
  • QJson
      QJson是一个基于Qt的开发包用来将JSON数据解析成QVariant对象,JSON的数组将被映射为QVariantList实例,而其他对象映射为QVariantMap实例。
      网址: http://qjson.sourceforge.net/.

    关于Qt中对 JSON 的生成与解析,Qt5以前的版本,需要去进行单独下载、编译,才能使用。到了Qt5,提供了专门的QJsonDocument类来读取和写入JSON文档。

Qt5中JSON的 生成与解析
  • QJsonDocument
       QJsonDocument既可以从一个基于文本表示的UTF-8编码,又可以从Qt自己的二进制格式读取和写入这个文件。
      JSON文档可以从它的基于文本的表示使用QJsonDocument::fromJson()转换为QJsonDocument,用.toJSON()将其转换回文字。解析器非常快速和高效,将JSON转换为二进制表示。
  • QJsonObject
      QJsonObject类用于封装JSON对象。
      JSON对象是键值对,其中键是唯一的字符串,其值由QJsonValue代表。一个QJsonObject可以从QVariantMap转换/被转换。
  • QJsonArray
      QJsonArray类用于封装JSON数组。
      一个JSON数组列表值。该列表可以通过从阵列插入和移除QJsonValue的操纵。一个QJsonArray可以从QVariantList转换为/被转换。

      QJsonDocument有效解析后的文档可以使用!iSNull()判断。使用isArray()和isObject()来判断是否包含一个数组或对象。文档中包含的数组或对象可以使用array()或object()进行检索,然后读取或操纵。

示例
QJsonObject
(1)生成Json
QJsonObject json;
json.insert("name", QString("Qt"));
json.insert("version", 5);
json.insert("windows", true);

QJsonDocument document;
document.setObject(json);
QByteArray byte_array = document.toJson(QJsonDocument::Compact);
QString json_str(byte_array);

结果:
json_str:{"name": "Qt","version": 5,"windows": true}

(2)解析Json
QJsonParseError json_error;
QJsonDocument parse_doucment = QJsonDocument::fromJson(byte_array, &json_error); 
if(json_error.error == QJsonParseError::NoError) 
{  
      if(parse_doucment.isObject())  
      {  
            QJsonObject obj = parse_doucment.object(); 
            if(obj.contains("name"))  
            {  
       QJsonValue name_value = obj.take("name");
       if(name_value.isString())
       {
             QString name = name_value.toString();
       }
if(obj.contains("version"))  
{  
       QJsonValue version_value = obj.take("version");
      if(version_value.isDouble())
       {
int version = version_value.toVariant().toInt();
       }
if(obj.contains("windows"))
{
       QJsonValue version_value = obj.take("windows");
       if(version_value.isBool())
      {
bool flag = version_value.toBool();
      } 
}
      }  
}  

结果:
name:Qt
version:5
windows:true

QJsonArray
(1)生成Json
QJsonArray json;
json.insert(0, QString("Qt"));
json.insert(1, QString("version"));
json.insert(2, true);

QJsonDocument document;
document.setArray(json);
QByteArray byte_array = document.toJson(QJsonDocument::Compact);
QString json_str(byte_array);

结果:
json_str:["Qt","version",true]

(2)解析Json
QJsonParseError json_error;
QJsonDocument parse_doucment = QJsonDocument::fromJson(byte_array, &json_error); 
if(json_error.error == QJsonParseError::NoError) 
{  
      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();
       }
}
      }
}

结果:
数组不同下标对应的值
0:Qt
1:version
2:true

      如上,简单介绍一下常用的JSON库以及Qt中对JSON的生成与解析,如需更多资料请参考官方文档,还是那句话,没有比助手更好、更专业的资料了!

注:
      技术在于交流、沟通,转载请注明出处并保持作品的完整性。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值