2

我正在尝试使用读取 2 个 json 文件StreamReader,将它们解析为JObjects,然后执行合并。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"} 
4

3 回答 3

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

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

于 2016-06-08T01:25:38.140 回答
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);
           }
    }

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

于 2016-06-08T05:30:26.183 回答
0

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

于 2016-06-08T08:15:03.563 回答