cJSON读写数据例子

cJSON使用案例代码。

#include <stdio.h>
#include <stdlib.h>
#include "../cJson/cJSON.h"

int main() {
    FILE* jsonFile = fopen("data.json", "r");
    if (jsonFile) {
        fseek(jsonFile, 0, SEEK_END);
        int jsonFileSize = ftell(jsonFile);
        fseek(jsonFile, 0, SEEK_SET);
        char* jsonStr = (char*)malloc(jsonFileSize + 2);
        fread(jsonStr, jsonFileSize, 1, jsonFile);
        fclose(jsonFile);
        cJSON* root;
        root = cJSON_Parse(jsonStr);
        if (root) {
            cJSON* typeObj01 = cJSON_GetObjectItem(root, "type");
            if (typeObj01) {
                printf("type:%s\r\n", typeObj01->valuestring);
            }

            cJSON* crsObj = cJSON_GetObjectItem(root, "crs");
            if (crsObj) {
                cJSON* typeObj02 = cJSON_GetObjectItem(crsObj, "type");
                if (typeObj02) {
                    printf("type:%s\r\n", typeObj02->valuestring);
                }
                cJSON* propertiesObj1 = cJSON_GetObjectItem(crsObj, "properties");
                if (propertiesObj1) {
                    cJSON* nameObj = cJSON_GetObjectItem(propertiesObj1, "name");
                    if (nameObj) {
                        printf("name:%s\r\n", nameObj->valuestring);
                    }
                }
            }
            cJSON* featuresObj = cJSON_GetObjectItem(root, "features");
            if (featuresObj) {
                featuresObj = featuresObj->child;
                for (; featuresObj; featuresObj = featuresObj->next)
                {
                    cJSON* typeObj03 = cJSON_GetObjectItem(featuresObj, "type");
                    if (typeObj03) {
                        printf("type:%s\r\n", typeObj03->valuestring);
                    }
                    cJSON* propertiesobj = cJSON_GetObjectItem(featuresObj, "properties");
                    if (propertiesobj) {
                        cJSON* IDObj = cJSON_GetObjectItem(propertiesobj, "ID");
                        cJSON* ELEVObj = cJSON_GetObjectItem(propertiesobj, "ELEV");
                        if (IDObj && ELEVObj){
                            printf("ID:%d, ELEV:%f\r\n", IDObj->valueint, ELEVObj->valuedouble);
                        }
                        
                    }
                }
            }
            cJSON_Delete(root);
        }
        free(jsonStr);
    }
    return 1;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/710760.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++的一些细节技巧

列表和数组的区别 【C】list使用 1.C中怎么把字符串放到list&#xff1a; 在C中将字符串存入列表&#xff08;List&#xff09;可以使用标准库的std::list<std::string>。下面是示例代码&#xff1a; #include <iostream> #include <list> #include <st…

pt模型转换为onnx的作用,直接用pt模型去检测可以吗

将PyTorch模型转换为ONNX模型的作用主要在于提高模型的可移植性和兼容性&#xff0c;同时不能直接用PyTorch模型去检测的原因可能涉及到环境配置、性能优化等方面。 首先&#xff0c;关于将PyTorch模型转换为ONNX模型的作用&#xff0c;ONNX&#xff08;Open Neural Network E…

day57 集合 List Set Map

List实现类 List接口特点&#xff1a;元素有序 可重复 Arraylist 可变数组 jdk 8 以前Arraylist容量初始值10 jdk8 之后初始值为0&#xff0c;添加数据时&#xff0c;容量为10&#xff1b; ArrayList与Vector的区别&#xff1f; LinkList&#xff1a;双向链表 优点&#xff1…

智慧工地物联网云平台APP源码:监管端、工地端、危大工程、智慧大屏

目录 技术说明 智慧工地 服务对象&#xff1a;项目现场 企业项目管理 服务对象&#xff1a;建设领域企业 政府工地监管 服务对象&#xff1a;全国各省建设领域政府机构 劳务实名制管理解决方案 绿色施工解决方案 视频监控解决方案 塔机安全监控解决方案 施工升降机安…

Windows安装Docker 容器教程(转载)

Windows安装Docker 容器教程 Docker Desktop - WSL distro terminated abruptlyA WSL distro Docker Desktop relies on has exited une Docker Desktop - Unexpected WSL error

【tableau学习笔记】tableau无法连接数据源

【tableau学习笔记】tableau无法连接数据源 背景&#xff1a; 学校讲到Tableau&#xff0c;兴奋下载Kaggle Excel&#xff0c;一看后缀CSV&#xff0c;导入Tableau发现报错“tableau无法连接数据源”&#xff0c;自作聪明改为后缀XLSX&#xff0c;bug依旧。 省流&#xff1a…

【DIY】TA7376组成的耳机放大电路

用头戴式耳机&#xff0c;尤其是小型耳机听音乐&#xff0c;总感到音乐味不够足&#xff0c;在低频段的效果更差。因此用本机增强耳机的低频特性&#xff0c;并采用立体声反相合成的办法&#xff0c;加上内藏简易矩阵环绕声电路&#xff0c;能获得强劲的低音和在较宽的范围内展…

构建一个基于Node.js的文件存储服务

随着现代web应用程序变得越来越复杂和功能强大&#xff0c;文件存储服务成为了许多应用的重要组成部分。在本篇博客中&#xff0c;我们将探讨如何构建一个基于Node.js的文件存储服务&#xff0c;让您可以轻松地上传、下载和管理文件。我们将利用Node.js的强大功能和模块来构建这…

美观的404错误页面源码

超级简单又美观的404模板&#xff0c;css文件全部集成在index.html&#xff0c;源码由HTMLCSSJS组成&#xff0c;记事本打开源码文件可以进行内容文字之类的修改&#xff0c;双击html文件可以本地运行效果&#xff0c;也可以上传到服务器里面&#xff0c;重定向这个界面 下载地…

苍穹外卖知识点总结(一)

简介 技术选型 展示项目中使用到的技术框架和中间件。 用户层&#xff1a;node.js Vue.js ElementUI 微信小程序 apache echarts 网关层&#xff1a;nginx 应用层&#xff1a;Spring Boot Spring MVC Spring Task httpclie…

对齐了之后才舒服,matplotlib文字和字体设置

文章目录 text方法字体局部字体 matplotlib教程&#xff1a; 初步&#x1f4c8; 子图绘制&#x1f4c8; 坐标投影&#x1f4c8; 刻度设置&#x1f4c8; 共享坐标轴&#x1f4c8; 内容填充 text方法 【plt】提供了文字显示函数text&#xff0c;包含三个必不可少的参数&am…

全量知识系统问题及SmartChat给出的答复 之7 三套工具之2

Q17. 三套工具的功能 问&#xff1a;以上代码中并没有体现出三套工具的功能性。 前端&#xff1a; 自动化或规则化 应用评测工具-“MOCK” &#xff08;会有三种不同的自动化程度&#xff1a;全自动化&#xff0c;半自动化和全人工&#xff09;&#xff0c;中间 &#xff1a; …

【QT+QGIS跨平台编译】之五十八:【QGIS_CORE跨平台编译】—【qgsexpression_texts.cpp生成】

文章目录 一、Python二、生成来源三、构建过程3.1 构建qgsexpression_texts.cpp.temp3.2 构建qgsexpression_texts.cpp一、Python python.exe 是 Python 解释器的可执行文件,用于在命令行中运行 Python 脚本。它是 Python 编程语言的解释器程序,负责解析和执行 Python 代码。…

第十四届校模拟赛第一期(一)

“须知少时凌云志&#xff0c;自许人间第一流” 鄙人11月八号有幸参加学校校选拔赛&#xff0c;题型为5道填空题&#xff0c;5道编程题&#xff0c;总时间为4小时。奈何能力有限&#xff0c;只完成了5道填空和3道编程大题&#xff0c;现进行自省自纠&#xff0c;分享学习&#…

改进YOLO系列 | YOLOv5/v7 引入通用高效层聚合网络 GELAN | YOLOv9 新模块

今天的深度学习方法专注于如何设计最合适的目标函数,以使模型的预测结果最接近真实情况。同时,必须设计一个合适的架构,以便为预测提供足够的信息。现有方法忽视了一个事实,即当输入数据经过逐层特征提取和空间转换时,会丢失大量信息。本文将深入探讨数据通过深度网络传输…

[AutoSar]BSW_Com06 CAN报文应用层到Can总线的函数调用

目录 关键词平台说明一、背景二、PDU转换三、函数调用 关键词 嵌入式、C语言、autosar、OS、BSW 平台说明 项目ValueOSautosar OSautosar厂商vector &#xff0c;芯片厂商TI 英飞凌编程语言C&#xff0c;C编译器HighTec (GCC)autosar版本4.3.X >>>>>回到总目…

流水账-20240229

目录 git本地回滚到到120bc409ee3b8f63a23d0060e55118bcce557acf提交记录本地提交到已有代码分支 IDEA批量导入快捷键无效更换背景主题快捷键快捷键可以设置eclipse模式&#xff0c;但是有些不生效&#xff0c;可能是冲突了Ctrl单击&#xff0c;Eclipse里面是可以跳转到代码内部…

AI:139-基于深度学习的语音指令识别与执行

🚀点击这里跳转到本专栏,可查阅专栏顶置最新的指南宝典~ 🎉🎊🎉 你的技术旅程将在这里启航! 从基础到实践,深入学习。无论你是初学者还是经验丰富的老手,对于本专栏案例和项目实践都有参考学习意义。 ✨✨✨ 每一个案例都附带关键代码,详细讲解供大家学习,希望…

js实现文件下载,并传给后端

在JavaScript中&#xff0c;可以通过创建一个链接并设置其href属性为文件的URL&#xff0c;然后使用download属性指定文件的名称来实现文件下载。以下是一个简单的示例代码&#xff1a; function downloadFile(url, filename) {const link document.createElement(a);link.hr…

Vue3自定义文件列表页面(含上传、搜索、复制链接)

文章目录 一、代码展示二、代码解读三、结果展示 一、代码展示 <template><div class"container"><h1>文件列表</h1><div class"header-actions"><a-input placeholder"输入关键词搜索" v-model:value"…