如何在不知道Key值的情况下读取Json数据

时间:2015-06-15 05:58:07

标签: c# asp.net json asp.net-web-api json.net

我有一个json数据作为输入字符串。现在我需要用输入的Json数据更新现有的Json数据。在我的例子中,我希望遍历每个键并与现有的Json数据匹配,然后使用输入的Json数据更新该键的

用于检索现有数据的代码

var existingJSon = ProductRepository.ListOfProd.Cast<JArray>().Where(x => x["ProdId"].ToString() == id.ToString());

检索数据后,我现有的Json将如下所示。

{
    ProdId:"1",
    Title:"C#",
    Author:"Jeffy",
    Publisher:"XYZ",
    Category:"Microsoft"
    }

现在我需要遍历作为输入的每个键并匹配现有的Json键并更新该键的值。

输入和更新后它应如下所示:

{
ProdId:"1",
Title:"C#",
Author:"Jeffy",
Publisher:"abcd",
Category:"Microsfot Basic .Net Development Kit"
}

1 个答案:

答案 0 :(得分:3)

看看这是否对您有所帮助,我们可以使用Newtonsoft反序列化未知类型并循环键和值。

string json = "{ProdId:\"1\",Title:\"C#\",Author:\"Jeffy\",Publisher:\"XYZ\",Category:\"Microsoft\"}";
        JObject obj = JsonConvert.DeserializeObject < JObject>(json);
        var properties = obj.Properties();
        foreach (var prop in properties)
        {
            string key = prop.Name;
            object value = prop.Value;
        }