目录
- 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数据
- 首先添加一些头文件
#include <QFile> // 用于打开文件 #include <QJsonParseError> // 返回错误信息 #include <QJsonArray> // Json数据对象 #include <QJsonDocument> // Json文档对象 #include <QJsonObject> // 普通Json对象 #include <QDebug> // 打印数据
复制
- 新建一个函数解析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<roots.size(); 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 类型