RapidJSON生成json格式文件

Json串:
花括弧表示一个“容器”
方括号装载数组
名称和值用冒号隔开
数组元素通过逗号隔开

JSON示例

{
    "name":"jack",	//常规类型
    "age":18,
    "sub":["a","b"],	//value是数组
    "elp":[ {"a":"A","b":"B"},	//value是一个数组且里面每个元素又是一个json格式
            {"c":"C","d":"D"},
          ]
}
string createJson()
{
	//常规操作
	Document doc;			//生成DOM元素
	doc.SetObject();
	Document::AllocatorType& allocator = doc.GetAllocator();	//生成一个分配器

	//构建键值对
	doc.AddMember("name","jack",allocator);				//键 值 分配器
	doc.AddMember("age", 18, allocator);

	//"sub"
	//构建数组 类型为:["1","2"]
	Value array_sub(kArrayType);						//创建一个数组类型对象
	array_sub.PushBack("a", allocator);
	array_sub.PushBack("b", allocator);

	doc.AddMember("sub", array_sub, allocator);		//将数组分配给sub字段
	//构建数组 类型为:[{"a":"A","b","B"},{"c":"C"}]	一个数组且里面每个元素又是一个json

	//"elp"
	Value array_json(kArrayType);		//一维数组

	Value array_obj1(kObjectType);		//每个数组里又是一个json格式 二级json
	array_obj1.AddMember("a","A",allocator);
	array_obj1.AddMember("b", "B", allocator);
	array_json.PushBack(array_obj1, allocator);

	Value array_obj2(kObjectType);		// 二级json
	array_obj2.AddMember("c", "C", allocator);
	array_obj2.AddMember("d", "D", allocator);
	array_json.PushBack(array_obj2, allocator);
	doc.AddMember("elp", array_json, allocator);

	StringBuffer s;
	Writer<StringBuffer> writer(s);
	doc.Accept(writer);

	return std::string(s.GetString());	
}

//读取json文件
void  ReadJson()
{
	FILE* fp = fopen("..//test.json","rb");
	char readBuffer[65536];
	FileReadStream is(fp, readBuffer, sizeof(readBuffer));
	Document d;
	d.ParseStream(is);
	fclose(fp);

	printf("%s", readBuffer);
}

void writeFiles(string str)			//写入json文件
{
	Document docu;
	string writeJson = str;
	docu.Parse(writeJson.c_str());
	FILE* fp = fopen("..//test.json", "wb");
	char writeBuffer[65535];
	rapidjson::FileWriteStream os(fp, writeBuffer, sizeof(writeBuffer));

	PrettyWriter<FileWriteStream> writer(os);
	docu.Accept(writer);
	fclose(fp);
}

int main()
{
	string result = createJson();
	writeFiles(result);	//写入json文件

	cout << "读取json文件:" << endl;
	ReadJson();

	return 0;
}
C++中,RapidJSON是一个快速、轻量级的JSON库,它非常适合处理JSON数据。如果你想使用RapidJSON生成JSON文件,你需要包含`rapidjson/document.h`和`rapidjson/writer.h`头文件,并创建一个`Document`对象来构建JSON内容,然后使用`Writer`来写入文件。 以下是一个简单的示例,展示如何生成JSON文件并设置指定路径: ```cpp #include "rapidjson/document.h" #include "rapidjson/writer.h" #include "rapidjson/stringbuffer.h" #include <fstream> #include <string> using namespace rapidjson; // 创建JSON数据 Document d; d.SetObject(); d.AddMember("key1", "value1", d.GetAllocator()); d.AddMember("key2", 42, d.GetAllocator()); // 设置文件路径 std::string filePath = "path/to/your/json/file.json"; // 创建文件流 std::ofstream file(filePath); // 创建Writer并写入文件流 if (file.is_open()) { Writer<fstream> writer(file); writer.write(d.Accept(writer)); file.close(); } else { // 处理文件打开失败的情况 std::cerr << "Failed to open file for writing." << std::endl; } // 修改JSON文件名(如果需要在程序运行时更改) std::string newFileName = "new_json_file.json"; std::string newFilePath = "path/to/new/" + newFileName; std::ifstream oldFile(filePath); std::ofstream newFile(newFilePath); if (oldFile.is_open() && newFile.is_open()) { std::copy(std::istreambuf_iterator<char>(oldFile), {}, newFile); oldFile.close(); newFile.close(); std::remove(filePath.c_str()); // 删除旧文件 } ``` 在这个例子中,我们首先创建了JSON文档并添加了一些键值对。然后,我们指定了一个文件路径,并尝试打开文件进行写入。如果文件成功打开,我们将JSON内容写入到文件中。最后,我们展示了如何在运行时更改文件名,但这需要先读取原文件内容,再写入新文件,然后删除旧文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值