本文主要总结用Qt自带的类QFile、QJsonDocument、QJsonParseError、QJsonObject、QJsonArray、QJsonValue来解析已经写好的json文件。其中,json文件的创建可以直接新建一个txt文本,然后将其后缀改为*.json文件就行。如果要用Qt程序自动创建,可以参考这篇博客: https://blog.csdn.net/li491093957/article/details/52836925 (可以直接跳过注意,看下面的实例代码)

注意:想要解析json文件的主要思路如下:(QJsonValue可以通过函数QJsonValue::toObject()转换为QJsonObject对象)

a1先用QFile类将*.json文件所有内容读出,用到关键函数QByteArray QFile::readAll();

a2将读出的内容转换为QJsonDocument类,用到函数QJsonDocument::fromJson();

a3将QJsonDocument类转换为一个具体的对象QJsonObject,通过函数QJsonDocument::object()实现。

a4通过对对象QJsonObject进行操作,可以直接获取第一级的一对:键-值。可以直接用QJsonObject类的实例来操作。比如QJsonObject jsonObject;

QString keyValue =  jsonObject["name"].toString();

其中,keyValue的值就是json文件下对应的value值。

a5当对象QJsonObject里面是一组数组(即有符号[ ])时,需要将获取的对应键的值,转化为json数组QJsonArray,可以直接用函数QJsonObject.value()或者函数QJsonObject.take()来获取对应键的值。

QJsonValue arrayValue = jsonObject.value(QStringLiteral("recoveryPrimaryNode"));

获取对应键的值后将其复制给json数组QJsonArray,然后用函数QJsonArray::at(i)来获取该数组下的第i个元素,可以用循环for(int i=0;i<array.size();i++)来该数组。

当获取某个键对应的值后,可以通过函数QJsonValue::toObject()将该值转换为对象,然后对象就可以像一级键:值来获取对应键的值。

下面将通过一个实例介绍如何解析json文件。

json文件内容如下:

"name":"value", "secondName":{"thirdName":"thirdValue"}, "recoveryPrimaryNode":[ {"id":"1","iconTxt":"图片","iconName":"1.jpg"}, {"id":"2","iconTxt":"视频","iconName":"2.jpg"}, {"id":"3","iconTxt":"文本","iconName":"3.jpg"}, {"id":"4","iconTxt":"压缩包","iconName":"4.jpg"}]

1.1新建一个widget工程,不要勾选ui界面。然后分别在widget.h,widget.cpp,main.cpp分别添加如下代码。

widget.h

#ifndef WIDGET_H
#define WIDGET_H
#include <QWidget>
#include <QJsonDocument>
#include <QJsonParseError>
#include <QJsonObject>
#include <QJsonArray>
#include <QJsonValue>
#include <QFile>
class Widget : public QWidget
    Q_OBJECT
public:
    Widget(QWidget *parent = 0);
    void createView();
#endif // WIDGET_H

widget.cpp

#include "widget.h"
#include <QDebug>
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    createView();
void Widget::createView()
    /*解析json文件*/
    QFile file(":/data.json");
    file.open(QIODevice::ReadOnly | QIODevice::Text);
    QString value = file.readAll();
    file.close();
    QJsonParseError parseJsonErr;
    QJsonDocument document = QJsonDocument::fromJson(value.toUtf8(),&parseJsonErr);
    if(!(parseJsonErr.error == QJsonParseError::NoError))
        qDebug()<<tr("解析json文件错误!");
        return;
    QJsonObject jsonObject = document.object();
    qDebug()<<"jsonObject[name]=="<<jsonObject["name"].toString();
    if(jsonObject.contains(QStringLiteral("secondName")))
        QJsonValue jsonValueList = jsonObject.value(QStringLiteral("secondName"));
        QJsonObject item = jsonValueList.toObject();
        qDebug()<<"item[thirdName]=="<<item["thirdName"].toString();
    if(jsonObject.contains(QStringLiteral("recoveryPrimaryNode")))
        QJsonValue arrayValue = jsonObject.value(QStringLiteral("recoveryPrimaryNode"));
        if(arrayValue.isArray())
            QJsonArray array = arrayValue.toArray();
            for(int i=0;i<array.size();i++)
                QJsonValue iconArray = array.at(i);
                QJsonObject icon = iconArray.toObject();
                QString id = icon["id"].toString();
                QString iconTxt = icon["iconTxt"].toString();
                QString iconName = icon["iconName"].toString();
                qDebug()<<"id="<<id<<"iconTxt="<<iconTxt<<"iconName="<<iconName;

main.cpp

#include "widget.h"
#include <QApplication>
int main(int argc, char *argv[])
    QApplication a(argc, argv);
    Widget w;
    w.resize(960,640);
    w.show();
    return a.exec();

1.2程序构建运行后,结果如下图所示:

参考内容:

https://blog.csdn.net/li491093957/article/details/52836925

https://blog.csdn.net/fox64194167/article/details/50193447

http://www.cnblogs.com/SkySoot/archive/2012/04/17/2453010.html(Json结构详细解说)

本文主要总结用Qt自带的类QFile、QJsonDocument、QJsonParseError、QJsonObject、QJsonArray、QJsonValue来解析已经写好的json文件。其中,json文件的创建可以直接新建一个txt文本,然后将其后缀改为*.json文件就行。如果要用Qt程序自动创建,可以参考这篇博客:https://blog.csdn.net/li491093957/ar...
qt解析json的数据,需要使用的类有qjsonobject,qjsonarray,qjsondocument。 qjsondocument是用于读取或者写入json文件 qjsonarray是封装一个json数组 qjsonobject是封装一个json对象 要解析json,就需要先了解你需要解析json格式,然后在写对应的解析代码。 例如这样的一份json文件,我现在想要解析他。将文件中每一个值都进行输出。 解析json就像扒洋葱一样,一层一层的往下扒。我们可以看到第一层是一个array。 &quot;describe&quot;:&quot;an apple&quot;, &quot;icon&quot;:&quot;appleIcon&quot;, &quot;name&quot;:&quot;apple&quot; QJsonDoucument 它封装了一个完整的 JSON 文档,并且可以从 UTF-8 编码的基于文本的表示以及 Qt 自己的二进制格式读取和写入该文档。 QJsonArray JSON 数组是一个值列表。可以通过从数组中插入和删除 QJsonValue 来操作该列表。 QJsonObject JSON 对象是键值对的列表,其中键是唯一的字符串,值由 QJs
目录JSON解析对象解析数组解析数组对象混合解析对象数组混合解析Qt中内置了一个QJsonDocument类用来处理json文件,以及json字符串。解析JSON是一种存储结构化数据的格式。它有6种基本数据类型:bool、double、string、array、object、null测试数据 Qt json解析对象 代码 数组解析 Qt json解析数组代码 数组对象混合解析 Qt json解析代码 对象数组混合解析 QT使用json需要包含的头文件 #include&amp;lt;qjsondocument.h&amp;gt; #include&amp;lt;qjsonarray.h&amp;gt; #include&amp;lt;qjsonobject.h&amp;gt; #inclu...
00. 目录 文章目录00. 目录01. QJsonObject类简介02. 公有类型03. 公有成员方法04. 公有成员方法解析05. 参考示例06. 附录 01. QJsonObject类简介 Header: #include <QJsonObject> qmake: QT += core Since: Qt 5.0 ​ QJsonObject类用于封装JSON对象。JSON对...
文章目录Qt-Json相关类QJsonDocumentQJsonObjectQJsonArrayQJsonValueQJsonParseError构建json对象生成js文档json 解析 Qt-Json相关类 QJsonDocument QJsonDocument 类常用于读和写 JSON文档,这里的JSON文档可以是 二进制文档也可以是 UTF-8文档。 QJsonObject QJsonObject 类封装了一个JSON对象。JSON 对象是一个键值对 <key/value>,key 是独
序列化:将对象或数据结构转换为二进制序列 反序列化:二进制序列转换为对象或数据结构 序列化可以使对象或数据结构更方便地在网络上传输或者保存在本地文件中,反序列化可以快速地复原原有对象和数据结构,方便使用。 二、具体操作 Qt中提供了QDataStream类用于读写二进制文件,所以可以借助此类实现序列化和反序列化。 2.1、定义数据结构 #ifndef DATA_RECORD_H #define DATA_RECORD_H #include <QObject> #include &l // 打开 JSON 文件 QFile file("example.json"); if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) { qDebug() << "无法打开文件"; return -1; // 读取 JSON 数据 QByteArray data = file.readAll(); QJsonDocument doc = QJsonDocument::fromJson(data); if (doc.isNull()) { qDebug() << "无法解析 JSON 数据"; return -1; // 获取 JSON 对象 QJsonObject obj = doc.object(); // 输出 JSON 数据 qDebug() << "name:" << obj["name"].toString(); qDebug() << "age:" << obj["age"].toInt(); return a.exec(); 以上代码会读取名为 `example.json` 的 JSON 文件,并输出其中的 `name` 和 `age` 字段。如果 JSON 文件格式不正确,或者字段不存在,程序会输出相应的错误信息。