2. 使用JsonDocument
创建一个JsonDocument之后,默认初始化为空,调用 JsonDocument::isNull()会返回true,这个时候既可以代表当做jsonObject,也可以当做jsonArray,这取决于你插入第一个value的类型。
例2: doc 作为JsonArray使用
DynamicJsonDocument doc(1024);
3. as —— 获取顶节点,并把它转成T类型
DynamicJsonBuffer doc(1024);
4. to —— jsondocument转成T类型
函数说明:
5. clear —— 清除JsonDocument并释放内存空间
清除JsonDocument并释放内存空间
6. isNull —— 判断jsondocument是否为空
/**
7. memoryUsage —— jsondocument已使用内存字节数
函数说明:
8. remove —— 移除特定key和value
results.remove(0);
三. 解析构造相关
1.deserializeJson —— 解析json/** * 解析json * @param doc jsondocument对象 * @param input 输入内容 * @return DeserializationError 解析结果 */ // writable input => zero-copy DeserializationError deserializeJson(JsonDocument& doc, char* input); DeserializationError deserializeJson(JsonDocument& doc, char* input, size_t inputSize); // read-only input => duplication DeserializationError deserializeJson(JsonDocument& doc, const char* input); DeserializationError deserializeJson(JsonDocument& doc, const char* input, size_t inputSize); DeserializationError deserializeJson(JsonDocument& doc, const __FlashStringHelper* input); DeserializationError deserializeJson(JsonDocument& doc, const __FlashStringHelper* input, size_t inputSize); DeserializationError deserializeJson(JsonDocument& doc, const String& input); DeserializationError deserializeJson(JsonDocument& doc, const std::string& input); DeserializationError deserializeJson(JsonDocument& doc, Stream& input); DeserializationError deserializeJson(JsonDocument& doc, std::istream& input);
2. serializeJson —— 构造序列化json (串口打印json)
StaticJsonDocument<200> doc;
3. serializeJsonPretty —— 构造序列化json,格式化输出 (串口美化打印json)
/**
4. measureJson —— 计算构造序列化json的长度
/**
2. createNestedArray —— 在当前对象中添加子key,子value为json数组
StaticJsonDocument<256> doc;
3. createNestedObject —— 在当前对象中添加子key,子value为json对象
StaticJsonDocument<256> doc;
4. getMember —— 获取key对应的value (仅限JsonObject类型)
/**
5. getOrCreateMember —— 获取或者创建key对应的value(仅限JsonObject类型)
/**
2. createNestedArray —— 添加json数组
StaticJsonDocument<200> doc;
3. createNestedObject —— 添加json对象
StaticJsonDocument<200> doc;
4. getElement —— 获取index位置的元素(仅限JsonArray类型)
/**
5. getOrAddElement —— 获取或者创建index对应的value(仅限JsonArray类型)
同上
#include <Arduino.h>
#include "ArduinoJson.h"
String jsonStr = "{\"results\":[{\"location\":{\"id\":\"WW7MBNP039PE\",\"name\":\"泰安\",\"country\":\"CN\",\"path\":\"泰安,泰安,山东,中国\",\"timezone\":\"Asia/Shanghai\",\"timezone_offset\":\"+08:00\"},\"now\":{\"text\":\"晴\",\"code\":\"0\",\"temperature\":\"28\"},\"last_update\":\"2020-09-09T10:09:00+08:00\"}]}";
DynamicJsonDocument doc(512);
void setup()
{
Serial.begin(115200);
delay(3000);
}
void loop()
{
//解析JSON字符串
Serial.println("从jsonStr解码成的DynamicJsonDocument对象doc:");
deserializeJson(doc, jsonStr);
serializeJson(doc, Serial);
Serial.println("从doc对象转换成的JsonObject类型对象root:");
JsonObject root = doc.as<JsonObject>();
serializeJson(root, Serial);
Serial.println();
Serial.println(doc.memoryUsage());
Serial.println(measureJson(doc));
Serial.println(measureJsonPretty(doc));
Serial.println("root里有一个子JsonArray对象 results:");
JsonArray results = root["results"];
serializeJson(results, Serial);
Serial.println();
//JsonArray类型的数组results里面只有一个元素: JsonObject对象results[0],
//该元素有三个子对象 location, now, last_update
//location
Serial.println("JsonObject对象 results[0]中的子JsonObject对象location:");
JsonObject location = results[0]["location"];
serializeJson(location, Serial);
Serial.println();
Serial.println("从JsonObject对象location中取出id");
const char *id = location["id"];
Serial.println(id);
Serial.println("从JsonObject对象location中取出name");
const char *name = location["name"];
Serial.println(name);
Serial.println("从JsonObject对象location中取出country");
const char *country = location["country"];
Serial.println(country);
Serial.println("从JsonObject对象location中取出path");
const char *path = location["path"];
Serial.println(path);
Serial.println("从JsonObject对象location中取出timezone");
const char *timezone = location["timezone"];
Serial.println(timezone);
Serial.println("从JsonObject对象location中取出timezone_offset");
const char *timezone_offset = location["timezone_offset"];
Serial.println(timezone_offset);
//now
Serial.println("JsonObject对象 results[0]中的子JsonObject对象now(为了避免和timer中的now重名,把它叫做now1):");
JsonObject now1 = results[0]["now"];
serializeJson(now1, Serial);
Serial.println("从JsonObject对象now1中取出text");
const char *text = now1["text"];
Serial.println(text);
Serial.println("从JsonObject对象now1中取出code");
const char *code = now1["code"];
Serial.println(code);
Serial.println("从JsonObject对象now1中取出temperature");
const char *temperature = now1["temperature"];
Serial.println(temperature);
//last_update
const char *last_update = results[0].getMember("last_update");
Serial.println("last_update:");
Serial.println(last_update);
Serial.println();
delay(10000);
}
MimiClaw 是一款基于 ESP32-S3 芯片的超轻量级AI助手,适合嵌入式AI与物联网开发者快速部署本地化AI代理。本系列教程基于MimiClaw的Arduino移植版本进行讲解,小节主要讲解部署和测试。
就像我们用手机打开WiFi功能后可以浏览附近的可用WiFi。要将手机连接到热点,通常需要打开Wi-Fi设置应用程序,列出可用的网络,然后选择所需的热点。然后输入密码(或不输入密码),可以使用ESP32进行相同的操作。
本文本介绍配置飞书机器人为MimiClaw的一个输入/输出端,和添加一个控制WS2812与LED的控制技能。
一块 30 块钱的开发板 + 一个大模型 API,就能做出可以听懂人话的智能硬件。 本文记录完整安装过程和踩坑经验,确保你跟着做就能跑通。
本文将从手绘架构图入手,逐层拆解 MimiClaw 的分层设计、核心模块、数据流转与底层实现,带你解剖这只“智能虾”的技术骨架,看懂在 C 语言加持下,AI 智能体如何以可穿戴设备的形态,在你身边稳稳运行、离线服务、主动响应。
本文介绍如何在不脱离 ArduinoIDE 可视化开发的前提下,通过一个名为 platform.local.txt 的小文件,实现对 ESP32 编译流程的精准控制。
本文将系统分析程序体积增长的五大根源,并提供经过验证的优化方案,帮助减小固件大小。
本文所DIY的语音助手设备端使用的是MicroPython、服务端是Python,对于很多开发者来说MicroPython入门没难度。
本小节使用音频开发框架实现一个音频录制到文件的示例。
I2S协议通过BCLK、LRCLK和DATA三线精准传输音频数据,但时序边沿、帧格式、时钟源等细节常引发噪声或断连。本文详解ESP32的I2S实现,从协议原理到ESP-IDF v5.x代码配置,助你避开常见陷阱,确保音频稳定传输。