Qt框架之解析和构建Json格式数据-程序员不得不懂的一种数据格式。

本文主要是介绍Qt框架之解析和构建Json格式数据-程序员不得不懂的一种数据格式。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

json格式简介

    • 一、json格式简介
      • 1、概念
      • 2、json中的对象和数组
    • 二、Qt框架对json格式的主要支持类(以下说明根据官方文档翻译整理)
      • 1、QJsonDocument类
      • 2、QJsonObject类
      • 3、QJsonArray类
      • 4、QJsonValue类
    • 三、Json格式的构建与解析
      • 1、构建和解析的数据格式如下:
      • 2、构建与解析示例代码:
    • 四、推荐一个在线的json格式验证工具
      • 1、[json在线验证](https://www.json.cn/):https://www.json.cn/
      • 2、验证效果:

一、json格式简介

1、概念

JSON是一种轻量级的数据交换格式,采用key-value键值对的方式来存储数据,主要用于网络通讯传输、本地配置文件等,易于人阅读和编写。

2、json中的对象和数组

对象:采用大括号{},括起来,中间的以key-value的形式存储,形如{“name”:“ISmileLi”}。
数组:采用中括号[],括起来,中间的存储数据以逗号,分割开,形如[toby,ISmileLi]。

对象和数组之间可以相互嵌套使用。

二、Qt框架对json格式的主要支持类(以下说明根据官方文档翻译整理)

1、QJsonDocument类

QJsonDocument类提供了一种读写JSON文档的方法。
QJsonDocument是一个类,它包装一个完整的JSON文档,可以从UTF-8编码的基于文本的表示以及Qt自己的二进制格式读写该文档。
可以使用QJsonDocument::from JSON()将JSON文档,从基于文本的表示形式转换为QJsonDocument,使用toJson()将其转换回文本,解析器非常快速和高效,并将JSON转换为Qt使用的二进制表示。
可以使用isNull()查询解析文档的有效性!
可以使用isArray()和isObject()查询文档是否包含数组或对象。文档中包含的数组或对象可以使用array()或object()检索,然后读取或操作。
也可以使用fromBinaryData()或fromRawData()从存储的二进制表示创建文档。

2、QJsonObject类

QJsonObject类封装了一个JSON对象。
JSON对象是键-值对的列表,其中键是唯一的字符串,值由QJsonValue表示。
QJsonObject可以与QVariantMap进行转换。它提供了size、insert、remove等方法供使用并使用标准的C++迭代器模式迭代其内容。
QJsonObject是一个隐式共享的类,只要不修改它,它就与从中创建的文档共享数据。
可以通过QJsonDocument将对象转换为基于文本的JSON或者反向转换。

3、QJsonArray类

QJsonArray类封装了一个JSON数组。
JSON数组是一个值列表。可以通过从数组中插入和删除QJsonValue来操作列表。
QJsonArray可以与QVariantList进行转换。它提供了size、insert、remove等方法供使用,并使用标准的C++迭代器模式迭代其内容。
QJsonArray是一个隐式共享的类,只要不修改它,它就可以与QJsonDocument创建的文档共享数据。
可以通过QJsonDocument将数组转换为基于文本的JSON或者反向转换。

4、QJsonValue类

QJsonValue类用JSON封装一个值。
JSON是一种存储结构化数据的格式。它有6种基本数据类型:
布尔(Bool)、双精度(Double)、字符串(String)、数组(Array)、对象(Object)、空(Null)。
值可以表示上述任何数据类型。此外,QJsonValue还有一个特殊的标志来表示未定义的值,可以使用isUndefined()查询。
可以使用type()或访问器(如isBool()、isString()等)查询值的类型。同样,可以使用toBool()、toString()等将值转换为存储在其中的类型。
值在内部是严格类型化的,与QVariant相反,它不会尝试进行任何隐式类型转换。这意味着转换为不存储在值中的类型将返回默认的构造返回值

三、Json格式的构建与解析

1、构建和解析的数据格式如下:

{"ISmileLi": [{"info": {"id": "00000000","sex": "就不告诉你","age": "我还很年轻"},"location": {"city": "BeiJing","country": "中国"},"profession": "programmer"}]
}

2、构建与解析示例代码:

#include <QtCore/QCoreApplication>
#

这篇关于Qt框架之解析和构建Json格式数据-程序员不得不懂的一种数据格式。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/903599

相关文章

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T