c# - C# 读取两个 Json 文件并合并它们

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

我尝试使用 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"} 

最佳答案

您可以采用 JArray 并将第二个 Json 添加到第一个 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);
           }
    }

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

关于c# - C# 读取两个 Json 文件并合并它们,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37691664/

相关文章:

c# - 找不到使用 Json.Net 反序列化 Json 索引数组的方法

ios - XCODE 中的 Json.Net 错误 - System.Reflection.Emit

c# - 将 XML 读入字典

javascript - 在 JSON 文件中搜索。

jquery - Facebook Graph API 使用 Ajax 获取 JSON

java - 使用 gson 和 back 进行序列化不适用于泛型类型

c# - dataSet.GetXml() 不会为空列或空白列返回 xml

c# - 如何覆盖 ServiceStack 中的默认 404 页面?

c# - Automapper:无法为集合创建抽象类型的实例

c# - 具有geo_shape字段的文档不能反序列化?