读取两个 Json 文件并在 C# 中合并它们
Reading two Json Files and merging them in C#
我正在尝试使用 StreamReader
读取 2 个 json 文件,将它们解析为 JObject
,然后执行合并。但是,当第二次调用 StreamReader
时,我收到以下错误:
Error reading JObject from JsonReader. Current JsonReader item is not
an object: StartArray. Path '', line 1, position 1.
For the line:
string jsonUpdateFile = updatesr.ReadToEnd();
下面的代码:
var path = String.Format("{0}json\data.json", AppDomain.CurrentDomain.BaseDirectory);
string jsonOldFile = new StreamReader(path).ReadToEnd();
var updatepath = String.Format("{0}json\update.json", AppDomain.CurrentDomain.BaseDirectory);
string jsonUpdateFile = new StreamReader(updatepath).ReadToEnd();
var jsonO = JObject.Parse(jsonOldFile);
var jsonU = JObject.Parse(jsonUpdateFile);
//merge new json into old json
jsonO.Merge(jsonU);
//save to file
FileInfo file = new FileInfo(path);
file.Directory.Create();
string JsonToSave = JsonConvert.SerializeObject(jsonO);
System.IO.File.WriteAllText(@path, JsonToSave);
我想用合并做什么:
var jsonO = [{"id":"1234","name":"Bruce"},{"id":"5678","name":"Clark"}]
var jsonU = [{"id":"1234","name":"Wayne"}]
var merge = [{"id":"1234","name":"Wayne"},{"id":"5678","name":"Clark"}
var jsonO = JArray.Parse(jsonOldFile);
var jsonU = JArray.Parse(jsonUpdateFile);
使用 JArray 而不是 JObject 可以让我读入文件。Merge 没有按预期工作,但这是另一个线程的问题。
您可以使用 JArray 并将第二个 Json 添加到第一个,即像这个
var jsonO = JArray.Parse(jsonOldFile);
var jsonU = JArray.Parse(jsonUpdateFile);
foreach(JObject innerData in jsonU )
{
jsonO.Add(innerData);
}
为了更新另一个 json 我想你可以试试这个我不知道一次试一试
var jsonO = JArray.Parse(jsonOldFile);
var jsonU = JArray.Parse(jsonUpdateFile);
var item = jsonO.Children<JObject>();
foreach(JObject innerData in jsonU)
{
if(innerData[Id] == item[Id])
{
item[Name] = innerData[Name];
jsonO.Replace(item["Name"]);
//[or]
jsonO.Add(item["Name"});
}
else
{
jsonO.Add(innerData);
}
}
虽然我是新手,如果我错了请指正我很高兴学习..
通过查看上述错误,我猜测您的 update.json
文件格式不正确 json。请先使用 http://jsonlint.com/ 验证您的 json。
我正在尝试使用 StreamReader
读取 2 个 json 文件,将它们解析为 JObject
,然后执行合并。但是,当第二次调用 StreamReader
时,我收到以下错误:
Error reading JObject from JsonReader. Current JsonReader item is not an object: StartArray. Path '', line 1, position 1.
For the line: string jsonUpdateFile = updatesr.ReadToEnd();
下面的代码:
var path = String.Format("{0}json\data.json", AppDomain.CurrentDomain.BaseDirectory);
string jsonOldFile = new StreamReader(path).ReadToEnd();
var updatepath = String.Format("{0}json\update.json", AppDomain.CurrentDomain.BaseDirectory);
string jsonUpdateFile = new StreamReader(updatepath).ReadToEnd();
var jsonO = JObject.Parse(jsonOldFile);
var jsonU = JObject.Parse(jsonUpdateFile);
//merge new json into old json
jsonO.Merge(jsonU);
//save to file
FileInfo file = new FileInfo(path);
file.Directory.Create();
string JsonToSave = JsonConvert.SerializeObject(jsonO);
System.IO.File.WriteAllText(@path, JsonToSave);
我想用合并做什么:
var jsonO = [{"id":"1234","name":"Bruce"},{"id":"5678","name":"Clark"}]
var jsonU = [{"id":"1234","name":"Wayne"}]
var merge = [{"id":"1234","name":"Wayne"},{"id":"5678","name":"Clark"}
var jsonO = JArray.Parse(jsonOldFile);
var jsonU = JArray.Parse(jsonUpdateFile);
使用 JArray 而不是 JObject 可以让我读入文件。Merge 没有按预期工作,但这是另一个线程的问题。
您可以使用 JArray 并将第二个 Json 添加到第一个,即像这个
var jsonO = JArray.Parse(jsonOldFile);
var jsonU = JArray.Parse(jsonUpdateFile);
foreach(JObject innerData in jsonU )
{
jsonO.Add(innerData);
}
为了更新另一个 json 我想你可以试试这个我不知道一次试一试
var jsonO = JArray.Parse(jsonOldFile);
var jsonU = JArray.Parse(jsonUpdateFile);
var item = jsonO.Children<JObject>();
foreach(JObject innerData in jsonU)
{
if(innerData[Id] == item[Id])
{
item[Name] = innerData[Name];
jsonO.Replace(item["Name"]);
//[or]
jsonO.Add(item["Name"});
}
else
{
jsonO.Add(innerData);
}
}
虽然我是新手,如果我错了请指正我很高兴学习..
通过查看上述错误,我猜测您的 update.json
文件格式不正确 json。请先使用 http://jsonlint.com/ 验证您的 json。