由浅入深C系列八:如何高效使用和处理Json格式的数据

简介: 本文简要介绍在c语言环境中使用cJSON处理JSON数据的方法,及提供相关示例代码。

问题引入

最近的项目在用c处理后台的数据时,因为好多外部接口都在使用Json格式作为返回的数据结构和数据描述,如何在c中高效使用和处理Json格式的数据就成为了必须要解决的问题。

关于CJSON

经常使用Java开发的同学可能觉得这个不是个问题,fastjson对于Json格式的数据处理提供了很好的支持。顺着这个思路往下走后,在Json的官网上发现推荐了好几个c的功能库。根据个人使用的情况,综合易于上手和对Json数据操作的便捷性来说,推荐cJSON: cJSON on Github

示例代码

头文件引用

cJson可以直接在使用的地方引用,如下面这样。

#include "../include/cJSON.h"
#include "../include/cJSON_Utils.h"

也可能编译成so文件,作为库来使用。

处理数据

cJSON *json = NULL;
cJSON *jdata = NULL;
cJSON *jlists = NULL;
cJSON *jlist = NULL;

json = cJSON_Parse(resp->response); // 从项目接口中返回的Json格式的数据
if (json == NULL)
{
   
    // 解析失败的情况下进行错误处理。
    const char *error_ptr = cJSON_GetErrorPtr();
    if (error_ptr != NULL)
    {
   
        fprintf(stderr, "Error before: %s\n", error_ptr);
    }
    return OSMP_ERR;
}
// 获取对应的节点下的数据。我的项目中数据列表在{ data: { list: { xxx } } } 下。
// 可以seek到对应的节点下,获取到节点数据进行处理。
jdata = cJSON_GetObjectItemCaseSensitive(json, "data");
jlists = cJSON_GetObjectItemCaseSensitive(jdata, "list");

// 循环处理列表中的每一条数据。
// cJson通过一个macro来组织循环处理列表中的处理。为了便于Java开发同学理解,相当于Java中的
// for(String item : arrayList ) {
   
//     System.out.println(item);
// } 
cJSON_ArrayForEach(jlist, jlists)
{
   
    cJSON *id = cJSON_GetObjectItemCaseSensitive(jlist, "id");
    cJSON *projectnum = cJSON_GetObjectItemCaseSensitive(jlist, "projectnum");
    cJSON *name = cJSON_GetObjectItemCaseSensitive(jlist, "name");
    cJSON *status = cJSON_GetObjectItemCaseSensitive(jlist, "status");
    cJSON *contractamount = cJSON_GetObjectItemCaseSensitive(jlist, "contractamount");
    cJSON *income = cJSON_GetObjectItemCaseSensitive(jlist, "income");
    cJSON *actualpayment = cJSON_GetObjectItemCaseSensitive(jlist, "actualpayment");
    cJSON *managerName = cJSON_GetObjectItemCaseSensitive(jlist, "managerName");
    cJSON *nextmilestone = cJSON_GetObjectItemCaseSensitive(jlist, "nextmilestone");
    cJSON *plancomplettime = cJSON_GetObjectItemCaseSensitive(jlist, "plancomplettime");
    cJSON *countdown = cJSON_GetObjectItemCaseSensitive(jlist, "countdown");

    // 组装sql进行后处理。
    char* sql = (char*)malloc(sizeof(char*)*10240);
    sprintf(sql, 
            "insert into utmp_projectpageqrydetailinformation(id, projectnum, name ,status, contractamount, income, actualpayment, manager_name, nextmilestone, plancomplettime, countdown) values(%d, '%s', '%s', '%s', %d,  %d,  %d, '%s', '%s', '%s', '%s');", 
            id->valueint, projectnum->valuestring, name->valuestring, status->valuestring, 
            contractamount->valueint, income->valueint, actualpayment->valueint, managerName->valuestring, 
            nextmilestone->valuestring, plancomplettime->valuestring, countdown->valuestring);
}
// 后续可以做一些资源清理操作,防止memory leak导致应用coredump.

如果有什么使用上的问题,欢迎留言一起讨论。:)

相关文章
|
8天前
|
存储 JSON JavaScript
【chat-gpt问答记录】python将数据存为json格式和yaml格式
【chat-gpt问答记录】python将数据存为json格式和yaml格式
23 1
|
17天前
|
存储 JSON 分布式计算
DataWorks产品使用合集之如何在数据服务中处理JSON数据
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
36 11
|
13天前
|
存储 JSON JavaScript
使用Python处理JSON格式数据
使用Python处理JSON格式数据
|
21天前
|
JSON JavaScript IDE
JSON 数据格式化方法
JSON 数据格式化方法
30 3
|
14天前
|
JSON JavaScript 测试技术
掌握JMeter:深入解析如何提取和利用JSON数据
Apache JMeter教程展示了如何提取和使用JSON数据。创建测试计划,包括HTTP请求和JSON Extractor,设置变量前缀和JSON路径表达式来提取数据。通过Debug Sampler和View Results Tree监听器验证提取结果,然后在后续请求和断言中使用这些数据。此方法适用于复杂测试场景,提升性能和自动化测试效率。
26 0
|
10天前
|
JSON 关系型数据库 MySQL
实时计算 Flink版产品使用问题之在使用CDAS语法同步MySQL数据到Hologres时,如果开启了字段类型宽容模式,MySQL中的JSON类型会被转换为什么
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
13天前
|
JSON 数据格式 Python
python3 服务端使用CGI脚本处理POST的Json数据
python3 服务端使用CGI脚本处理POST的Json数据
26 6
|
13天前
|
JSON Java 数据格式
java读取接口返回的json数据 (二)
java读取接口返回的json数据 (二)
21 5
|
13天前
|
JSON Java 数据格式
java读取接口返回的json数据
java读取接口返回的json数据
22 5
|
12天前
|
JSON API 数据格式
如何用 Python 的 requests 库发送 JSON 数据的 POST 请求
使用 requests 库发送 JSON 数据的 POST 请求是一个非常简单且实用的操作。通过将目标 URL 和 JSON 数据传递给 requests.post 方法,你可以轻松发送请求并处理响应。本篇文章介绍了从安装 requests 库,到发送 JSON 数据的 POST 请求,再到处理响应的整个流程。希望这篇文章能帮助你更好地理解并应用这个强大的 HTTP 请求库。