作成日
2020/01/27最終更新
2022/05/02記事区分
一般公開C++ で JSON を扱う際に利用されるライブラリの一つに RapidJSON があります。基本的な使い方を記載します。
インストール
cmake を利用してビルドすると簡単です。
ヘッダーファイルのみが必要となります。
git clone https://github.com/Tencent/rapidjson.git
ls rapidjson/include/
rapidjson
CMakeLists.txt
cmake_minimum_required (VERSION 3.10)
add_executable(main main.cpp)
target_include_directories(main PRIVATE rapidjson/include)
各値は rapidjson::Value
として扱われます。rapidjson::Document
は DOM を表現しており、一つ以上の rapidjson::Value
を持ちます。
#include <rapidjson/document.h>
#include <rapidjson/writer.h>
#include <rapidjson/stringbuffer.h>
#include <iostream>
int main() {
// JSON 文字列をパースして DOM に変換します。
std::string json = "{\"project\":\"rapidjson\",\"stars\":10}";
rapidjson::Document d;
d.Parse(json.c_str());
// 内容を Get/Set します。
rapidjson::Value& s = d["stars"];
s.SetInt(s.GetInt() + 1);
// buffer、writer を作成した上で、DOM と関連付けます。
rapidjson::StringBuffer buffer;
rapidjson::Writer<rapidjson::StringBuffer> writer(buffer);
d.Accept(writer);
// buffer を経由して値を文字列として取り出せます。
std::cout << buffer.GetString() << std::endl;
return 0;
}
ビルドおよび実行例
mkdir build
cd build/
cmake ..
make
./main
{"project":"rapidjson","stars":11}
サンプルコード
#include <rapidjson/document.h>
#include <rapidjson/writer.h>
#include <rapidjson/stringbuffer.h>
#include <iostream>
int main() {
// 検証用の JSON を用意します。
std::string json = "{\"key\":\"aaa\", \"key2\":123, \"key3\":true, \"\key4\": null, \"\key5\":1.23}";
rapidjson::Document d;
d.Parse(json.c_str());
std::string json2 = "[{\"key\":\"aaa\", \"key2\":123}]";
rapidjson::Document d2;
d2.Parse(json2.c_str());
// root [] または {} です。
assert(!d.IsArray());
assert(d.IsObject());
assert(d2.IsArray());
assert(!d2.IsObject());
// キーの存在確認
assert(d.HasMember("key"));
// 型の確認
assert(d["key"].IsString());
std::cout << d["key"].GetString() << std::endl; //=> aaa
assert(d["key2"].IsInt());
std::cout << d["key2"].GetInt() << std::endl; //=> 123
assert(d["key5"].IsDouble());
std::cout << d["key5"].GetDouble() << std::endl; //=> 1.23
assert(d["key3"].IsBool());
assert(d["key3"].GetBool());
assert(d["key4"].IsNull());
// JSON 配列
for(rapidjson::SizeType i = 0; i < d2.Size(); i++) {
assert(d2[i].IsObject());
assert(d2[i]["key"].IsString());
}
// 型の判別
static const char* kTypeNames[] = { "Null", "False", "True", "Object", "Array", "String", "Number" };
for (rapidjson::Value::ConstMemberIterator itr = d.MemberBegin(); itr != d.MemberEnd(); ++itr) {
printf("Type of member %s is %s\n", itr->name.GetString(), kTypeNames[itr->value.GetType()]);
}
return 0;
}
関連記事
- ダウンキャスト (C++をもう一度)実行時型情報 RTTI #include <iostream> #include <typeinfo> using namespace std; class MyClass { public: virtual ~MyClass() {} // typeid で正しい RTTI // (RunTime Type Information; 実行時型情報) ...
- 競技プログラミングの基本処理チートシート (C++)限られた時間の中で問題を解くために必要となる、競技プログラミングにおける基本的な処理のチートシートです。競プロにおけるメジャー言語 C++ を利用します。その際 C++11 の機能は利用せず C++03 の機能の範囲内で記述します。 頻度高く定期的に開催されるコンテスト AtCoder Codeforces main.cpp #include <iostream>
- 構造体と列挙体 (C++をもう一度)構造体 #include <iostream> using namespace std; struct MyStruct { char charval; int intval; }; void Show(MyStruct* obj) { cout << obj->intval << endl; } int main() { ...
- Valgrind による C/C++ メモリリーク検出JVM メモリリークでは JDK の jstat や jmap で原因を調査できます。C/C++ では valgrind の Memcheck ツールが利用できます。valgrind には複数のツールが含まれており既定のツールが Memcheck です。他のツールを利用する場合は --tool オプションで指定します。 [簡単な利用例](h
- クラスの基本/初期化 (C++をもう一度)構造体のように初期化する (非推奨) #include <iostream> using namespace std; const int MAX_STR = 16; class MyClass { public: int m_integer; char m_str[MAX_STR + 1]; void Show(); }; void MyClass::Show...