Qt 5.14.2 深度解析:打造高效JSON处理利器

简介: Qt 5.14.2 深度解析:打造高效JSON处理利器

Qt 5.14.2 深度解析:打造高效JSON处理利器



参考资料


引言

在当今的软件开发世界中,JSON(JavaScript Object Notation)已经成为了数据交换的标准格式。Qt,作为一个跨平台的C++框架,自然也提供了强大的JSON处理能力。本文将带你深入Qt 5.14.2版本,探索如何利用其内置的JSON处理功能,打造一个高效、健壮的JSON处理系统。


一、JSON基础

JSON是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。它基于JavaScript的一个子集,但独立于语言,几乎所有的现代编程语言都提供了JSON解析和生成的支持。


二、Qt中的JSON处理

在Qt 5.14.2中,我们可以直接使用QJsonDocumentQJsonObjectQJsonArrayQJsonValue等类来处理JSON数据。这些类提供了从字符串到JSON对象的解析,以及从JSON对象到字符串的序列化功能。


三、核心类解析

  1. QJsonDocument:用于表示整个JSON文档。它可以是对象(QJsonObject)或数组(QJsonArray)。
  2. QJsonObject:表示JSON对象,即键值对的集合。它可以直接转换为QVariantMap
  3. QJsonArray:表示JSON数组,即值的有序集合。它可以转换为QVariantList
  4. QJsonValue:表示JSON中的一个值,它可以是字符串、数字、布尔值、数组、对象或null。


四、实战演练:构建JSON

让我们通过一个简单的例子来构建一个JSON对象:

QJsonObject jsonObj;
jsonObj.insert("name", "Qt");
jsonObj.insert("version", "5.14.2");
QJsonDocument doc;
doc.setObject(jsonObj);
QByteArray byteArray = doc.toJson(QJsonDocument::Compact);
QString jsonString = QString::fromUtf8(byteArray);


五、实战演练:解析JSON

解析JSON的过程与构建相反,我们需要从字符串中提取出JSON对象,并进行操作:

QJsonParseError error;
QJsonDocument doc = QJsonDocument::fromJson(byteArray, &error);
if (!doc.isNull() && error.error == QJsonParseError::NoError) {
    QJsonObject obj = doc.object();
    QString name = obj.value("name").toString();
    QString version = obj.value("version").toString();
    // 使用解析出的数据
}


六、高级应用:处理复杂JSON

处理复杂的JSON结构,如嵌套的对象和数组,需要递归地解析和构建。以下是一个包含嵌套对象和数组的JSON示例:

QJsonObject companyObj;
companyObj.insert("name", "Qt Company");
companyObj.insert("website", "https://www.qt.io");
QJsonArray versionsArray;
versionsArray.append("5.8");
versionsArray.append("5.9");
versionsArray.append("5.10");
QJsonObject rootObj;
rootObj.insert("company", QJsonValue(companyObj));
rootObj.insert("versions", QJsonValue(versionsArray));
// 序列化和反序列化过程与前面示例相同


七、错误处理

在解析JSON时,我们需要特别注意错误处理。QJsonParseError类提供了错误类型和位置信息,帮助我们定位问题。


八、JsonHandler 工具类的封装及测试

#include <QCoreApplication>
#include <QFile>
#include <QIODevice>
#include <QJsonDocument>
#include <QJsonObject>
#include <QJsonArray>
#include <QMap>
#include <QList>
#include <QString>
#include <QTextStream>
#include <QDebug>
class JsonHandler {
public:
    JsonHandler() : root() {}
    // 加载JSON文件
    bool load(const QString &fileName) {
        QFile file(fileName);
        if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) {
            qWarning() << "Failed to open file for reading:" << qPrintable(file.errorString());
            return false;
        }
        QJsonParseError parseError;
        QJsonDocument doc = QJsonDocument::fromJson(file.readAll(), &parseError);
        if (doc.error() != QJsonDocument::NoError) {
            qWarning() << "JSON parsing error at offset" << parseError.offset << ":" << qPrintable(parseError.errorString());
            return false;
        }
        root = doc.object();
        return true;
    }
    // 保存JSON到文件
    bool save(const QString &fileName) const {
        QFile file(fileName);
        if (!file.open(QIODevice::WriteOnly | QIODevice::Text)) {
            qWarning() << "Failed to open file for writing:" << qPrintable(file.errorString());
            return false;
        }
        QJsonDocument doc(root);
        QTextStream stream(&file);
        stream << doc.toJson(QJsonDocument::Indented);
        file.close(); // Ensure the file is properly closed
        return true;
    }
    // 获取JSON对象的值
    template <typename T>
    T getValue(const QString &key, const T &defaultValue = T()) const {
        QJsonValue value = root.value(key)
;
        if (value.isUndefined()) {
            return defaultValue;
        }
        if (value.isString() && typeid(T) == typeid(QString)) {
            return value.toString();
        } else if (value.isDouble() && typeid(T) == typeid(double)) {
            return value.toDouble();
        } else if (value.isBool() && typeid(T) == typeid(bool)) {
            return value.toBool();
        } else if (value.isInteger() && typeid(T) == typeid(int)) {
            return value.toInt();
        }
        qWarning() << "Value type mismatch for key" << key;
        return defaultValue;
    }
    // 获取JSON数组的元素
    template <typename T>
    QList<T> getArrayValues(const QString &key) const {
        QJsonArray array = root.value(key).toArray();
        QList<T> list;
        for (const QJsonValue &value : array) {
            if (value.isString() && typeid(T) == typeid(QString)) {
                list.append(value.toString());
            } else if (value.isDouble() && typeid(T) == typeid(double)) {
                list.append(value.toDouble());
            } else if (value.isBool() && typeid(T) == typeid(bool)) {
                list.append(value.toBool());
            } else if (value.isInteger() && typeid(T) == typeid(int)) {
                list.append(value.toInt());
            }
        }
        return list;
    }
    // 设置JSON值
    template <typename T>
    void setValue(const QString &key, const T &value) {
        if (typeid(T) == typeid(QString)) {
            root.insert(key, value.toString());
        } else if (typeid(T) == typeid(double)) {
            root.insert(key, value.toDouble());
        } else if (typeid(T) == typeid(bool)) {
            root.insert(key, value.toBool());
        } else if (typeid(T) == typeid(int)) {
            root.insert(key, value.toInt());
        } else if (typeid(T) == typeid(QJsonValue)) {
            root.insert(key, value);
        } else {
            qWarning() << "Unsupported value type for key" << key;
        }
    }
    // 删除JSON键
    bool remove(const QString &key) {
        if (root.contains(key)) {
            root.remove(key)
;
            return true;
        }
        return false;
    }
    // 将JSON对象转换为QMap<QString, QJsonValue>
    QMap<QString, QJsonValue> jsonObjectToMap() const {
        QMap<QString, QJsonValue> map;
        for (auto it = root.begin(); it != root.end(); ++it) {
            map.insert(it.key(), it.value());
        }
        return map;
    }
private:
    QJsonObject root;
};
#include <QDebug>
int main(int argc, char *argv[]) {
    QCoreApplication app(argc, argv);
    JsonHandler jsonHandler;
    QString jsonFileName = "example.json";
    // 加载JSON文件
    if (jsonHandler.load(jsonFileName)) {
        // 示例:获取不同类型的值
        QString stringValue = jsonHandler.getValue<QString>("stringKey");
        double doubleValue = jsonHandler.getValue<double>("doubleKey");
        bool boolValue = jsonHandler.getValue<bool>("boolKey");
        int intValue = jsonHandler.getValue<int>("intKey");
        // 修改JSON数据
        jsonHandler.setValue("newKey", "newValue");
        jsonHandler.setValue("doubleKey", 3.14);
        jsonHandler.setValue("boolKey", true);
        jsonHandler.setValue("intKey", 42);
        // 保存修改后的JSON文件
        if (jsonHandler.save(jsonFileName)) {
            qDebug() << "JSON file saved successfully.";
        } else {
            qDebug() << "Failed to save JSON file.";
        }
    } else {
        qDebug() << "Failed to load JSON file.";
    }
    return 0;
}


九、总结

JSON处理是现代软件开发中不可或缺的一部分。Qt 5.14.2为我们提供了强大的支持,让我们可以轻松地在C++项目中处理JSON数据。希望本文能够帮助你更好地理解和使用Qt的JSON处理功能。如果你有任何问题或想要深入讨论,欢迎在评论区留言,让我们一起探索Qt的无限可能!

相关文章
|
27天前
|
JSON 定位技术 PHP
PHP技巧:解析JSON及提取数据
这就是在PHP世界里探索JSON数据的艺术。这场狩猎不仅仅是为了获得数据,而是一种透彻理解数据结构的行动,让数据在你的编码海洋中畅游。通过这次冒险,你已经掌握了打开数据宝箱的钥匙。紧握它,让你在编程世界中随心所欲地航行。
124 67
|
4月前
|
数据采集 JSON 数据可视化
JSON数据解析实战:从嵌套结构到结构化表格
在信息爆炸的时代,从杂乱数据中提取精准知识图谱是数据侦探的挑战。本文以Google Scholar为例,解析嵌套JSON数据,提取文献信息并转换为结构化表格,通过Graphviz制作技术关系图谱,揭示文献间的隐秘联系。代码涵盖代理IP、请求头设置、JSON解析及可视化,提供完整实战案例。
307 4
JSON数据解析实战:从嵌套结构到结构化表格
|
6月前
|
JSON 前端开发 搜索推荐
关于商品详情 API 接口 JSON 格式返回数据解析的示例
本文介绍商品详情API接口返回的JSON数据解析。最外层为`product`对象,包含商品基本信息(如id、name、price)、分类信息(category)、图片(images)、属性(attributes)、用户评价(reviews)、库存(stock)和卖家信息(seller)。每个字段详细描述了商品的不同方面,帮助开发者准确提取和展示数据。具体结构和字段含义需结合实际业务需求和API文档理解。
|
6月前
|
JSON 小程序 UED
微信小程序 app.json 配置文件解析与应用
本文介绍了微信小程序中 `app.json` 配置文件的详细
998 12
|
6月前
|
JSON 缓存 API
解析电商商品详情API接口系列,json数据示例参考
电商商品详情API接口是电商平台的重要组成部分,提供了商品的详细信息,支持用户进行商品浏览和购买决策。通过合理的API设计和优化,可以提升系统性能和用户体验。希望本文的解析和示例能够为开发者提供参考,帮助构建高效、可靠的电商系统。
180 12
|
7月前
|
JSON JavaScript 前端开发
一次采集JSON解析错误的修复
两段采集来的JSON格式数据存在格式问题,直接使用PHP的`json_decode`会报错。解决思路包括:1) 手动格式化并逐行排查错误;2) 使用PHP-V8JS扩展在JavaScript环境中解析。具体方案一是通过正则表达式和字符串替换修复格式,方案二是利用V8Js引擎执行JS代码并返回JSON字符串,最终实现正确解析。 简介: 两段采集的JSON数据因掺杂JavaScript代码导致PHP解析失败。解决方案包括手动格式化修复和使用PHP-V8JS扩展在JavaScript环境中解析,确保JSON数据能被正确处理。
|
24天前
|
JSON API 数据格式
淘宝商品评论API接口,json数据示例参考
淘宝开放平台提供了多种API接口来获取商品评论数据,其中taobao.item.reviews.get是一个常用的接口,用于获取指定商品的评论信息。以下是关于该接口的详细介绍和使用方法:
|
2月前
|
SQL JSON 数据格式
SPL 处理多层 JSON 数据比 DuckDB 方便多了
esProc SPL 处理多层 JSON 数据比 DuckDB 更便捷,尤其在保留 JSON 层次与复杂计算时优势明显。DuckDB 虽能通过 `read_json_auto()` 将 JSON 解析为表格结构,但面对深层次或复杂运算时,SQL 需频繁使用 UNNEST、子查询等结构,逻辑易变得繁琐。而 SPL 以集合运算方式直接处理子表,代码更简洁直观,无需复杂关联或 Lambda 语法,同时保持 JSON 原始结构。esProc SPL 开源免费,适合复杂 JSON 场景,欢迎至乾学院探索!
|
4月前
|
XML JSON API
淘宝商品详情API的调用流程(python请求示例以及json数据示例返回参考)
JSON数据示例:需要提供一个结构化的示例,展示商品详情可能包含的字段,如商品标题、价格、库存、描述、图片链接、卖家信息等。考虑到稳定性,示例应基于淘宝开放平台的标准响应格式。
|
4月前
|
JSON Java 数据格式
微服务——SpringBoot使用归纳——Spring Boot返回Json数据及数据封装——封装统一返回的数据结构
本文介绍了在Spring Boot中封装统一返回的数据结构的方法。通过定义一个泛型类`JsonResult&lt;T&gt;`,包含数据、状态码和提示信息三个属性,满足不同场景下的JSON返回需求。例如,无数据返回时可设置默认状态码&quot;0&quot;和消息&quot;操作成功!&quot;,有数据返回时也可自定义状态码和消息。同时,文章展示了如何在Controller中使用该结构,通过具体示例(如用户信息、列表和Map)说明其灵活性与便捷性。最后总结了Spring Boot中JSON数据返回的配置与实际项目中的应用技巧。
238 0

推荐镜像

更多