【QT 读取JSON】 深入浅出 使用QT内置的QJson模块解析Json文件 匠心之作

目录

  • 0 引言
  • 1 Json数据分析
  • 2 解析Json数据
    • 🙋‍♂️ 作者:海码007
    • 📜 专栏:QT专栏
    • 💥 标题:【QT 读取JSON】 使用QT内置的QJson模块解析Json文件
    • ❣️ 寄语:人生的意义或许可以发挥自己全部的潜力,所以加油吧!
    • 🎈 最后:文章作者技术和水平有限,如果文中出现错误,希望大家能指正

    0 引言

    在项目开发过程中,经常会遇到读写Json文件的需求,掌握Json文件的操作是基础中的基础。

    1 Json数据分析

    要读取的Json数据格式如下:

    [
            {
                "name":"ggr",
                "info":
                    {
                        "age":21,
                        "height":174
                    }
            },
            {
                "name":"lbw",
                "info":
                    {
                        "age":21,
                        "height":174
                    }
            }
    ]
    

    接下来以QJson模块的角度,来解析这个Json数据

    整个文件数据可以转换为 QJsonDocument 类型,其中有 “[ ]” 方括号、 "{ }“花括号、” : "冒号。

    • 被 “[ ]” 方括号包围的数据是QJsonArray数组类型。
    • 被 "{ }"花括号包围的数据是QJsonObject对象类型。
    • " : "冒号两侧的分别是Key和Value(key : value),冒号左右有空格不影响数据读取。

    先了解四个重要的类型

    • QJsonDocument类型,指的是整个Json数据。
    • QJsonArray数组类型的元素是QJsonValue类型。
    • QJsonObject类型的元素是键值对,也就是 Key: Value 类型。Key 是字符串类型,Value 的类型是 QJsonValue
    • QJsonValue类型 可以转换成 QJsonObject 类型、int型、double型、QString类型、QJsonArray类型等基础数据类型。

    总结:QJsonDocument 可以转换为 QJsonArray 或QJsonObjec t类型。然后 QJsonArray 中的元素和 QJsonObject 中键值对的值的类型都是 QJsonValue 类型。QJsonValue 类型可以转换成QJsonArray、QJsonObject、int、double、QString、bool等类型。(相当于闭环了,设计的非常巧妙)

    2 解析Json数据

    1. 首先添加一些头文件
    #include // 用于打开文件
    #include // 返回错误信息
    #include // Json数据对象
    #include // Json文档对象
    #include // 普通Json对象
    #include // 打印数据
    
    1. 新建一个函数解析Json数据
    bool ReadJson::praseJsonFile(const QString &sJsonPathFn)
    { //---------------------------------------------------------------------------------------------
        //1.读取磁盘中的文件
        QFile file( sJsonPathFn );
        if (!file.open(QIODevice::ReadOnly)) return false;
        QJsonParseError result;
        QJsonDocument   root_Doc = QJsonDocument::fromJson(file.readAll(), &result);    // 将文件数据格式化为JsonDocument对象
        if( result.error != QJsonParseError::NoError ) return false;                    // 数据格式错误就返回
        //---------------------------------------------------------------------------------------------
        QJsonArray roots = root_Doc.array();   // 将JsonDocument对象转换为QJsonArray类型
        //---------------------------------------------------------------------------------------------
        //2.遍历QJsonArray数组
        for (int i=0; i QJsonObject root = roots.at(i).toObject();
            // 读取name和info的值
            QString     name    = root.value("name").toString();
            QJsonObject info    = root.value("info").toObject();
            // 读取info对象中age和height的值
            int         age     = info.value("age").toInt();
            int         height  = info.value("height").toInt();
            // 打印读取的数据
            qDebug() << "name = " << name;
            qDebug() << "info.age = " << age;
            qDebug() << "info.height = " << height;
        }
        //---------------------------------------------------------------------------------------------
        return true;
    }
    

    其实只要掌握关键的函数,就能看懂上面的代码:

    • readAll()

      这是将文本文件读取成 QByteArray 类型的函数

    • QJsonDocument的fromJson(const QByteArray &json, QJsonParseError *error = Q_NULLPTR)函数

      这是将 QByteArray 类型的字符数组转换成 QJsonDocument 类型的函数。

    • QJsonDocument 有两个函数,分别是 object() 和 array() 函数,它们可以将自己转换成 QJsonArray 类型或者 QJsonObject 类型

      使用 object() 还是 array() 函数就看Json数据最开头的是 方括号 还是 花括号 ,本文数据是方括号开头,所以使用的是 array() 函数。

    • QJsonArray 的 at(int index) 函数,用于访问数组索引等于 index 的元素。
    • QJsonObject 的 value(const QString &key) 函数,用于读取花括号中的键值对的值。根据key的值,读取value的值。

      该函数返回的是 QJsonValue 类型

    • QJsonValue 中的 toObject、toString、toInt、toDouble、toBool、toArray 函数用于将 QJsonValue 装换为 QJsonObject、QString、int、double、bool、QJsonArray 类型