Qt平台下使用QJson构建JSON字符串

简介: Qt平台下使用QJson构建JSON字符串

640.jpg

前言

上两篇文章介绍了使用cJSON库解析和构建JSON字符串Qt平台下使用QJson解析JSON字符串

本篇文章介绍,Qt开发环境下使用QJson库构建JSON字符串,开发平台基于Qt 5.8 Windows。

JSON的构建包括:

  • 简单的键值对
  • JSON对象作为键的值
  • JSON数组
  • JSON数组的嵌套


QJson构建JSON字符串示例

关于JSON字符串的介绍,可以参考JSON简介

首先,解析和构建都要包含如下头文件:

#include <QJsonDocument>
#include <QJsonObject>
#include <QJsonArray>


1.构建一个简单的键值对JSON

void Create_Simple_JSON(void)
{
    //创建JSON对象
    QJsonObject root_Obj;
    //添加键值对,值的类型自动识别,顺序不可自定义
    root_Obj.insert("CSDN", "https://blog.csdn.net/whik1194");
    root_Obj.insert("cnblogs", "https://home.cnblogs.com/u/whik/");
    root_Obj.insert("Github", "https://github.com/whik/");
    root_Obj.insert("Blog", "https://www.wangchaochao.top/");
    root_Obj.insert("status", 1);
    root_Obj.insert("enable", true);
    root_Obj.insert("update_time", "20190723");
    //创建Json文档
    QJsonDocument root_Doc;
    root_Doc.setObject(root_Obj);
    QByteArray root_str = root_Doc.toJson(QJsonDocument::Compact);  //紧凑格式
//    QByteArray root_str = root_Doc.toJson(QJsonDocument::Indented);   //标准JSON格式    QString strJson(root_str);
    QString strJson(root_str);
    qDebug() << strJson;
}


输出结果

{
    "Blog": "https://www.wangchaochao.top/",
    "CSDN": "https://blog.csdn.net/whik1194",
    "Github": "https://github.com/whik/",
    "cnblogs": "https://home.cnblogs.com/u/whik/",
    "enable": true,
    "status": 1,
    "update_time": "20190723"
}


2.构建北京时间JSON字符串

void Create_BJTime_JSON(void)
{
    QJsonObject result_Obj;
    result_Obj.insert("timestamp", "ok");
    result_Obj.insert("datetime_1", "2019-07-21 10:46:57");
    result_Obj.insert("datetime_2", "2019年07月21日 10时46分57秒");
    result_Obj.insert("week_1", "0");
    result_Obj.insert("week_2", "星期日");
    result_Obj.insert("week_3", "周日");
    result_Obj.insert("week_4", "Sunday");
    QJsonObject root_Obj;
    //添加键值对,值的类型自动识别,顺序不可自定义
    root_Obj.insert("status", "success");
    root_Obj.insert("Blog", "www.wangchaochao.top");
    root_Obj.insert("result", result_Obj);
    //创建Json文档
    QJsonDocument root_Doc;
    root_Doc.setObject(root_Obj);
    QByteArray root_str = root_Doc.toJson(QJsonDocument::Compact);  //紧凑格式
//    QByteArray root_str = root_Doc.toJson(QJsonDocument::Indented);   //标准JSON格式
//    qDebug() << root_str; //中文输出乱码
    QString strJson(root_str);
    qDebug() << strJson;
}


输出结果

{
    "status": "success",
    "result": {
        "timestamp": "ok",
        "datetime_1": "2019-07-21 10:46:57",
        "datetime_2": "2019年07月21日 10时46分57秒",
        "week_1": "0",
        "week_2": "星期日",
        "week_3": "周日",
        "week_4": "Sunday"
    },
    "Blog": "www.wangchaochao.top"
}


3.构建字符串数组

void Create_Array_Str_JSON(void)
{
    QJsonArray root_Arr;
    root_Arr.insert(0, "Sunday");
    root_Arr.insert(1, "Monday");
    root_Arr.insert(2, "Tuesday");
    root_Arr.insert(3, "Wednesday");
    root_Arr.insert(4, "Thursday");
    root_Arr.insert(5, "Friday");
    root_Arr.insert(6, "Saturday");
    //创建Json文档
    QJsonDocument root_Doc;
    root_Doc.setArray(root_Arr);
    QByteArray root_str = root_Doc.toJson(QJsonDocument::Compact);  //紧凑格式
//    QByteArray root_str = root_Doc.toJson(QJsonDocument::Indented);   //标准JSON格式
//    qDebug() << root_str; //中文输出乱码
    QString strJson(root_str);
    qDebug() << strJson;
}


输出结果

["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"]


4.构建数组JSON

void Create_Array_JSON(void)
{
    QJsonObject day0_Obj;
    QJsonObject day1_Obj;
    QJsonObject day2_Obj;
    day0_Obj.insert("date", "2019-07-21");
    day0_Obj.insert("cond_txt", "多云");
    day0_Obj.insert("cond_code", "101");
    day0_Obj.insert("hum", "23");
    day0_Obj.insert("tmp_H", "31");
    day0_Obj.insert("tmp_L", "25");
    day1_Obj.insert("date", "2019-07-21");
    day1_Obj.insert("cond_txt", "阵雨");
    day1_Obj.insert("cond_code", "107");
    day1_Obj.insert("hum", "44");
    day1_Obj.insert("tmp_H", "30");
    day1_Obj.insert("tmp_L", "26");
    day2_Obj.insert("date", "2019-07-22");
    day2_Obj.insert("cond_txt", "晴");
    day2_Obj.insert("cond_code", "100");
    day2_Obj.insert("hum", "20");
    day2_Obj.insert("tmp_H", "33");
    day2_Obj.insert("tmp_L", "26");
    QJsonArray weather_Arr;
    weather_Arr.insert(0, day0_Obj);
    weather_Arr.insert(1, day1_Obj);
    weather_Arr.insert(2, day2_Obj);
    QJsonObject root_Obj;
    root_Obj.insert("status", "ok");
    root_Obj.insert("update", "2019-07-21 11:00");
    root_Obj.insert("Blog", "www.wangchaochao.top");
    root_Obj.insert("weather", weather_Arr);    //数组作为weather键的值
    //创建Json文档
    QJsonDocument root_Doc;
    root_Doc.setObject(root_Obj);
    QByteArray root_str = root_Doc.toJson(QJsonDocument::Compact);  //紧凑格式
//    QByteArray root_str = root_Doc.toJson(QJsonDocument::Indented);   //标准JSON格式
//    qDebug() << root_str; //中文输出乱码
    QString strJson(root_str);
    qDebug() << strJson;
}


输出结果

{
    "status": "ok",
    "weather": [{
        "date": "2019-07-21",
        "cond_txt": "多云",
        "cond_code": "101",
        "hum": "23",
        "tmp_H": "31",
        "tmp_L": "25"
    }, {
        "date": "2019-07-22",
        "cond_txt": "晴",
        "cond_code": "100",
        "hum": "20",
        "tmp_H": "33",
        "tmp_L": "26"
    }, {
        "date": "2019-07-23",
        "cond_txt": "阵雨",
        "cond_code": "107",
        "hum": "45",
        "tmp_H": "32",
        "tmp_L": "25"
    }],
    "update": "2019-07-21 11:00",
    "Blog": "www.wangchaochao.top"
}


5.构建数组嵌套的JSON字符串

void Create_Array_Nest_JSON(void)
{
    QJsonArray table_Arr = {"地区", "92号汽油", "95号汽油", "98号汽油", "0号柴油"};
    QJsonArray bj_Arr = {"北京", "6.78", "7.21", "8.19", "6.45"};
    QJsonArray sh_Arr = {"上海", "6.74", "7.17", "7.87", "6.39"};
    QJsonArray js_Arr = {"江苏", "6.75", "7.18", "8.06", "6.37"};
    QJsonArray tj_Arr = {"天津", "6.77", "7.15", "8.07", "6.41"};
    QJsonArray data_Arr;    //数组内嵌套了5个数组
    data_Arr.insert(0, table_Arr);
    data_Arr.insert(1, bj_Arr);
    data_Arr.insert(2, sh_Arr);
    data_Arr.insert(3, js_Arr);
    data_Arr.insert(4, tj_Arr);
    QJsonObject root_Obj;
    root_Obj.insert("status", "ok");
    root_Obj.insert("msg", "全国各省份汽柴油价格信息");
    root_Obj.insert("update", "2019-07-21");
    root_Obj.insert("About", "wcc");
    root_Obj.insert("Blog", "www.wangchaochao.top");
    root_Obj.insert("data", data_Arr);  //数组作为键的值
    //创建Json文档
    QJsonDocument root_Doc;
    root_Doc.setObject(root_Obj);
    QByteArray root_str = root_Doc.toJson(QJsonDocument::Compact);  //紧凑格式
//    QByteArray root_str = root_Doc.toJson(QJsonDocument::Indented);   //标准JSON格式
//    qDebug() << root_str; //中文输出乱码
    QString strJson(root_str);
    qDebug() << strJson;
}


输出结果

{
    "status": "ok",
    "msg": "全国各省份汽柴油价格信息",
    "update": "2019-07-21",
    "data": [
        ["地区", "92号汽油", "95号汽油", "98号汽油", "0号柴油"],
        ["北京", "6.78", "7.21", "8.19", "6.45"],
        ["上海", "6.74", "7.17", "7.87", "6.39"],
        ["江苏", "6.75", "7.18", "8.06", "6.37"],
        ["天津", "6.77", "7.15", "8.07", "6.41"]
    ],
    "About": "wcc",
    "Blog": "www.wangchaochao.top"
}


目录
相关文章
|
2天前
|
JSON JavaScript 前端开发
js将json字符串还原为json
【6月更文挑战第15天】js将json字符串还原为json
11 4
|
11天前
Cmake构建Qt项目链接glog库
Cmake构建Qt项目链接glog库
|
13天前
|
JSON Java 数据格式
将JSON格式的字符串转换成List集合引入gson 的jar包
将JSON格式的字符串转换成List集合引入gson 的jar包
|
22天前
|
SQL 存储 JSON
Hive 解析 JSON 字符串数据的实现方式
Hive 提供 `get_json_object` 函数解析 JSON 字符串,如 `{&quot;database&quot;:&quot;maxwell&quot;}`。`path` 参数使用 `$`、`.`、`[]` 和 `*` 来提取数据。示例中展示了如何解析复杂 JSON 并存储到表中。此外,Hive 3.0.0及以上版本内置 `JsonSerDe` 支持直接处理 JSON 文件,无需手动解析。创建表时指定 `JsonSerDe` 序列化器,并在 HDFS 上存放 JSON 文件,可以直接查询字段内容,方便快捷。
|
25天前
|
SQL JSON 监控
实时计算 Flink版产品使用合集之直接将 JSON 字符串解析为数组的内置函数如何解决
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
1月前
|
JSON JavaScript 前端开发
js将json字符串还原为json对象
【5月更文挑战第14天】js将json字符串还原为json对象
47 1
|
1月前
|
C语言 容器
【qt】QString字符串2
【qt】QString字符串2
11 0
|
1月前
|
C++
【qt】QString字符串1
【qt】QString字符串1
21 0
|
1月前
|
Windows 安全 C++
Qt字符串类应用与常用基本数据类型
Qt字符串类应用与常用基本数据类型
|
1月前
|
存储 JSON DataWorks
DataWorks产品使用合集之DataWorks将 MongoDB 中的数组类型写入到 DataWorks 的单个字段时,表示为字符串格式而非 JSON 格式如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
31 3

热门文章

最新文章