JSON&cJSON

JSON是一种开放的、轻量级的数据交换格式,采用独立于编程语言的文本格式(字

符串)来存储和表示数据,JSON数据以键-值对的形式组织,可以包含对象、数组、字符

串、数字、布尔、NULL这6种基本数据类型。

使用cJSON保函#include "cJSON.h"

其中\为转义字符

使用cJSON对JSON字符进行解析

1.解析JSON

cpp 复制代码
cJSON* js_root = cJSoN_Parse(json_str);

2.获取id键值对里面的值

cpp 复制代码
cJSON * id_js = cJSON_GetObjectItem(js_root,"id");
ESP_LOGI(TAG,"id:%s",cJSON_GetStringValue(id_js));

cJSON * id_js = cJSON_GetObjectItem(js_root,"id")的含义为从js_root中提取键名为"id"的数据,提取后的值为cJSON格式保存在id_js中,

ESP_LOGI(TAG,"id:%s",cJSON_GetStringValue(id_js));为将提取的cJson类型的数值转换为字符串并打印

3.version

cpp 复制代码
cJSoN* version_js = cJsoN_GetobjectItem(js_root,"version");
ESP_LOGI(TAG,"version:%s",cJSoN_GetStringValue(version_js));

4.sys

cpp 复制代码
cJSoN* sys_js = cJSoN_GetobjectItem(js_root,"sys");
cJSON* ack_js = cJSON_GetObjectItem(sys_js,"ack");
ESP_LOGI(TAG,"ack:%s",cJSON_GetStringValue(aCk_js));

5.params

cpp 复制代码
cJSoN* params_js = cJsoN_GetobjectItem(js_root,"params");
cJSoN* power_js = cJSoN_GetObjectItem(params_js,"power");
cJSoN* value_js = cJSoN_GetObjectItem(power_js,"value");
cJSON* time_js = cJsoN_GetobjectItem(power_js,"time");
ESP_LOGI(TAG,"value:%s",cJSON_GetStringValue(value_js));
ESP_LOGI(TAG,"time:%.1lf",cJSON_GetNumberValue(time_js));

6.method

cpp 复制代码
cJSoN* method_js = cJSoN_GetObjectItem(js_root,"method");
ESP_LOGI(TAG,"method:%s",cJSON_GetStringValue(method_js));

7.数组

cpp 复制代码
cJSoN* array_js = cJSoN_GetobjectItem(js_root,"array");
cJSON* sub_js = array_js->child;
int num =0;
while(sub_js)
ESP_LOGI(TAG,"array[%d]:%s",num,cJSON_GetStringValue(sub_js));
sub_js = sub_js->next;
num++;

8.释放CJSON

cpp 复制代码
cJSON_Delete(js_root);

生成JSON字符串

1.生成JSON对象

cpp 复制代码
cJSON * js_root =cJSON_CreatObject();

2.id

cpp 复制代码
cJSON_AddStringToObject(js_root,"id","123");

3.version

cpp 复制代码
cJSON_AddStringToObject(js_root,"version","1.0");

4.sys

cpp 复制代码
cJSON*sys_js= cJSON_CreateObject();
cJSON_AddNumberToObject(sys_js,"ack",1.0);
cJSoN_AddItemToObject(js_root,"sys",sys_js);

5.params

cpp 复制代码
cJSoN *params_js = cJSoN_Createobject();
cJSON *power_js = cJSoN_CreateObject();
cJSoN_AddStringToObject(power_js,"value","on");
cJSoN_AddStringToobject(power_js,"time",1524448722000);
cJSoN_AddItemToObject(params_js,"Power",power_js);
cJSoN_AddItemToObject(js_root,"Params",params_js);

6.array数组

cpp 复制代码
cJSON* array_js = cJSON_CreateArray();
cJSoN_AddItemToArray(array_js,cJSoN_CreateString("string1"));
cJSoN_AddItemToArray(array_js,cJSoN_CreateString("string2"));
cJSoN_AddItemToArray(array_js,cJSoN_CreateString("string3"));
cJSoN_AddItemToObject(js_root,"array",array_js);

7.打印创建的JSON

cpp 复制代码
char* js_str = cJsoN_PrintUnformatted(js_root);
//char* js_str =cJSON_Print(js_root);
ESP_LOGI(TAG,"js:\r(n:%s",js_str);

8.释放内存

cpp 复制代码
cJSON_free(js_str);
cJSON_Delete(js_root);
相关推荐
じòぴé南冸じょうげん7 小时前
小程序的project.private.config.json是无依赖文件,那可以删除吗?
前端·小程序·json
luckys.one21 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
小菜全1 天前
基于若依框架Vue+TS导出PDF文件的方法
javascript·vue.js·前端框架·json
CodeCraft Studio1 天前
Excel处理控件Aspose.Cells教程:使用 Python 将 Pandas DataFrame 转换为 Excel
python·json·excel·pandas·csv·aspose·dataframe
敬业小码哥2 天前
记一次:mysql的json及json数组使用组合使用
数据库·mysql·json
一键三联啊2 天前
BSON 和 JSON 的区别
json
一个很老的小萌新3 天前
json 解析 [{“id“:1,“name“:“apple“},{“id“:2,“name“:“banana“}]
java·前端·json
微笑伴你而行4 天前
目标检测如何将同时有方形框和旋转框的json/xml标注转为txt格式
xml·目标检测·json
cdcdhj4 天前
数据库存储大量的json文件怎么样高效的读取和分页,利用文件缓存办法不占用内存
缓存·node.js·json
Z_z在努力5 天前
【杂类】JSON:现代Web开发的数据交换基石
json