zoukankan      html  css  js  c++  java
  • JsonCpp的简单使用方法

    JsonCpp 是一个C++用来处理JSON 数据的开发包。下面讲一下怎么使用JsonCpp来序列化和反序列化Json对象,以实际代码为例子。
    
    反序列化Json对象
    
    比如一个Json对象的字符串序列如下,其中”array”:[...]表示Json对象中的数组:
    {“key1″:”value1″,”array”:[{"key2":"value2"},{"key2":"value3"},{"key2":"value4"}]},那怎么分别取到key1和key2的值呢,代码如下所示:
    
        std::string strValue = “{\”key1\”:\”value1\”,\”array\”:[{\"key2\":\"value2\"},{\"key2\":\"value3\"},{\"key2\":\"value4\"}]}”;
    
        Json::Reader reader;
        Json::Value value;
    
        if (reader.parse(strValue, value))
        {
        std::string out = value["key1"].asString();
        std::cout << out << std::endl;
        const Json::Value arrayObj = value["array"];
        for (int i=0; i<arrayObj.size(); i++)
        {
        out = arrayObj[i]["key2"].asString();
        std::cout << out;
        if (i != arrayObj.size() – 1 )
        std::cout << std::endl;
        }
        }
    
    序列化Json对象
    
    先构建一个Json对象,此Json对象中含有数组,然后把Json对象序列化成字符串,代码如下:
    
        Json::Value root;
        Json::Value arrayObj;
        Json::Value item;
        for (int i=0; i<10; i++)
        {
        item["key"] = i;
        arrayObj.append(item);
        }
    
        root["key1"] = “value1″;
        root["key2"] = “value2″;
        root["array"] = arrayObj;
        root.toStyledString();
        std::string out = root.toStyledString();
        std::cout << out << std::endl;
    
    删除Json对象
        std::string strContent = "{\"key\":\"1\",\"name\":\"test\"}";
    
        Json::Reader reader;
    
        Json::Value value;
    
        if (reader.parse(strContent, value))
        {
            Json::Value root=value;
    
            root.removeMember("key");
    
            printf("%s \n",root.toStyledString().c_str());
  • 相关阅读:
    https://developer.aliyun.com/ebook?utm_content=g_1000256420
    形容词在句子中的位置
    顺风水水
    https://www.youtube.com/watch?v=pVIywLXDuRo 有趣到流泪
    经济机器是怎样运行的 (时长30分钟) Ray Dalio
    https://codepen.io/deadzq-the-decoder/pen/qBqQYXg
    Vue 10 test
    vue day2
    codepen学Vue day2
    代理总结更新
  • 原文地址:https://www.cnblogs.com/ytjjyy/p/2453348.html
Copyright © 2011-2022 走看看