读取两个Json文件并在C#中合并它们

时间:2016-06-08 00:51:38

标签: c# json json.net streamreader system.io.file

我正在尝试使用StreamReader读取2个json文件,将它们解析为JObject,然后执行合并。但是,当第二次调用StreamReader时,我收到以下错误:

  

从JsonReader读取JObject时出错。当前的JsonReader项目不是   一个对象:StartArray。路径'',第1行,第1位。

     

对于该行:       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"} 

3 个答案:

答案 0 :(得分:0)

var jsonO = JArray.Parse(jsonOldFile);
var jsonU = JArray.Parse(jsonUpdateFile);

使用JArray而不是JObject允许我读取文件。合并没有按预期工作,但这是另一个线程的问题。

答案 1 :(得分:0)

你可以拿JArray并将第二个Json添加到First One,就像这个

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);
           }
    }

即使我是新手,如果我错了,请纠正我很高兴学习它..

答案 2 :(得分:0)

通过查看有问题的错误,我的猜测是你的update.json文件不是有效的json格式。请先使用http://jsonlint.com/验证您的json。