读取两个 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。