Qt中json的使用方法

关于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)创建josn文件
    QJsonObject json;
    json.insert("lisi","safaf");
    json.insert("lisi2",100);

    QJsonDocument document(json);
    QByteArray byteArray=document.toJson(QJsonDocument::Compact);
    QString str(byteArray);
    
//解析json文件
    QJsonParseError json_err;
    QJsonDocument   parse_doucment=QJsonDocument::fromJson(byteArray,&json_err);
    if(json_err.error==QJsonParseError::NoError)
    {
        if(parse_doucment.isObject())
        {
            QJsonObject obj=parse_doucment.object();
            if(obj.contains("lisi"))
            {
                QJsonValue lisi_value=obj.take("lisi");
                if(lisi_value.isString())
                {
                    QString lisi=lisi_value.toString();
                    qDebug()<<lisi;
                }
            }
            if(obj.contains("lisi2"))
            {
                QJsonValue lisi2_value=obj.take("lisi2");
                if(lisi2_value.isDouble())
                {
                    int lisi2=lisi2_value.toInt();
                    qDebug()<<lisi2;
                }
            }
        }
    }

第二种方法使用QJsonArray

//生成json格式文件
	QJsonArray json;
    json.insert(0,QString("hello"));
    json.insert(1,30);
    json.insert(2,false);

    QJsonDocument json_document(json);
    QByteArray byteArray=json_document.toJson(QJsonDocument::Compact);

    QString str(byteArray);
    qDebug()<<str;

//解析json文件
    QJsonParseError json_erro;
    QJsonDocument parse_dou=QJsonDocument::fromJson(byteArray,&json_erro);

    if(json_erro.error==QJsonParseError::NoError)
    {
        if(parse_dou.isArray())
        {
           QJsonArray array=parse_dou.array();
           for(int i=0;i<array.size();i++)
           {
               QJsonValue value=array.at(i);
               if(value.isBool())
                   qDebug()<<value.toBool();
               else if(value.isDouble())
                   qDebug()<<value.toInt();
               else
                   qDebug()<<value.toString();
           }
        }
    }
如上,简单介绍一下常用的JSON库以及Qt中对JSON的生成与解析,如需更多资料请参考官方文档,还是那句话,没有比助手更好、更专业的资料了!
欢迎关注问我团队公众号:

在这里插入图片描述

注:
技术在于交流、沟通,转载请注明出处并保持作品的完整性。
作者:一去丶二三里 原文:http://blog.sina.com.cn/s/blog_a6fb6cc90101gnxm.html。

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt,可以使用Qt提供的Json类来组织和解析数据。Qt从版本5.0开始提供了对Json的支持。主要有四个与Json相关的类常用:QJsonDocument、QJsonArray、QJsonObject和QJsonValue。 QJsonDocument类封装了一个完整的JSON文档,可以从基于文本的UTF-8编码的表示以及Qt的二进制格式读取和写入该文档。 QJsonArray表示JSON数组,是一个值的列表。可以通过插入和删除QJsonValue来操作该列表。 QJsonObject表示JSON对象,是键值对的列表,其键是唯一的字符串,值由QJsonValue表示。 QJsonValue类封装了JSON支持的数据类型。 QJsonParseError类用于报告JSON解析过程的错误。 对于Json使用,可以参考以上提到的类的文档和相关函数进行操作,根据具体的需求进行数据的组织和解析。Json格式的数据在Qt可以方便地进行处理,并且由于Json的数据格式与语言无关,因此在QtJson使用具有广泛的应用场景。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [【QTQt Json 的操作](https://blog.csdn.net/qq_43331089/article/details/124582761)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [【Qt专栏】QtJson使用教程](https://blog.csdn.net/weixin_43729127/article/details/127522889)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值