C#是否有用于解析多级级联JSON的库?

C#是否有用于解析多级级联JSON的库?,c#,json,parsing,serialization,C#,Json,Parsing,Serialization,是否有一个库(C#首选)来解析我所说的多级级联JSON 下面是我的意思的一个例子:(伪代码/C#) 结果(行为与CSS相同) 编辑1-更复杂的示例 const string json1 = @"{ ""firstName"": ""John"", ""lastName"": ""Smith"", ""age"": 25,

是否有一个库(C#首选)来解析我所说的多级级联JSON

下面是我的意思的一个例子:(伪代码/C#)

结果(行为与CSS相同)

编辑1-更复杂的示例

const string json1 =
                @"{
                     ""firstName"": ""John"",
                     ""lastName"": ""Smith"",
                     ""age"": 25,
                     ""address"": 
                     {
                         ""streetAddress"": ""21 2nd Street"",
                         ""city"": ""New York"",
                         ""state"": ""NY"",
                         ""postalCode"": ""10021""
                     },
                     ""phoneNumber"": 
                     [
                         {
                           ""type"": ""home"",
                           ""number"": ""212 555-1234""
                         },
                         {
                           ""type"": ""fax"",
                           ""number"": ""646 555-4567""
                         }
                     ]
                 }";

            const string json2 =
                @"{
                     ""firstName"": ""John2"",
                     ""lastName"": ""robert"",
                     ""age"": 25,
                     ""address"": 
                     {
                         ""state"": ""FL"",
                     },
                     ""phoneNumber"": 
                     [
                         {
                           ""type"": ""fax"",
                           ""number"": ""222 222-2222""
                         },
                         {
                           ""type"": ""iphone"",
                           ""number"": ""111 111-1111""
                         }
                     ]
                 }";

            const string json3 =
                @"{
                     ""firstName"": ""John3"",
                     ""father"": ""guy""
                 }";

            const string expectedResult =
                @"{
                     ""firstName"": ""John3"",
                     ""lastName"": ""robert"",
                     ""age"": 25,
                     ""father"": ""guy"",
                     ""address"": 
                     {
                         ""streetAddress"": ""21 2nd Street"",
                         ""city"": ""New York"",
                         ""state"": ""FL"",
                         ""postalCode"": ""10021""
                     },
                     ""phoneNumber"": 
                     [
                         {
                           ""type"": ""home"",
                           ""number"": ""212 555-1234""
                         },
                         {
                           ""type"": ""fax"",
                           ""number"": ""222 222-2222""
                         },
                         {
                           ""type"": ""iphone"",
                           ""number"": ""111 111-1111""
                         }
                     ]
                 }";
编辑2


在对需求进行了更多思考之后,我发现更复杂的示例永远无法按原样工作。例如,级联函数将无法知道某个电话号码是否已被修改或是否为新号码。为了使其正常工作,每个子实体都应该有一个唯一的标识符。

我不知道。对于简单的情况,您可以使用任何JSON库,然后使用类似的解决方案合并字典。例如,使用Newtonsoft/Json.NET:

Dictionary<String, String> dict1, dict2, dict3, merged;
dict1 = JsonConvert.DeserializeObject<Dictionary<string,string>>(json1);
dict2 = JsonConvert.DeserializeObject<Dictionary<string,string>>(json2);
dict3 = JsonConvert.DeserializeObject<Dictionary<string,string>>(json3);
merged = Merge(new[]{dict1, dict2, dict3});
字典dict1,dict2,dict3,合并;
dict1=JsonConvert.DeserializeObject(json1);
dict2=JsonConvert.DeserializeObject(json2);
dict3=JsonConvert.DeserializeObject(json3);
合并=合并(新[]{dict1,dict2,dict3});

显然,在生产代码中,您需要考虑到冗余行。

使用优秀的。此方法将对象与字符串、数字或对象等特性组合在一起

public static string Cascade(params string[] jsonArray)
{
    JObject result = new JObject();
    foreach (string json in jsonArray)
    {
        JObject parsed = JObject.Parse(json);
        foreach (var property in parsed)
            result[property.Key] = property.Value;
    }
    return result.ToString();
}
结果,给出您的示例:

{
  "firstName": "Albert",
  "lastName": "Smith",
  "phone": "12345"
}

编辑以回应您更新的问题: 通过调整此解决方案以递归方式工作,可以合并子对象。以下示例将匹配预期结果(数组除外)。您将能够以类似于合并对象(
JObject
)的方式轻松地扩展此解决方案以合并数组(
JArray


有趣。这不是一个典型的用例,所以我会非常惊讶它是否存在任何库。我现在正在写我自己的。不确定这是否有助于解决您的特定问题,但您可以看看,也不确定我是否正确理解了示例,但想知道结果应该是
Albert Smith
还是“John Albert”(如您所示),我根据您的更改更新了我的答案。但是,我将合并数组作为读者的练习。:)谢谢你的回答。这个解决方案的问题是,它只适用于简单的JSON对象。我的示例是LiteJSON,只是为了澄清问题。我编辑了我的示例以获得更复杂/详细的示例。谢谢您的回答。正如您所说,它可能适用于简单的情况,但我需要它适用于所有场景。
public static string Cascade(params string[] jsonArray)
{
    JObject result = new JObject();
    foreach (string json in jsonArray)
    {
        JObject parsed = JObject.Parse(json);
        foreach (var property in parsed)
            result[property.Key] = property.Value;
    }
    return result.ToString();
}
{
  "firstName": "Albert",
  "lastName": "Smith",
  "phone": "12345"
}
public static string Cascade(params string[] jsonArray)
{
    JObject result = new JObject();
    foreach (string json in jsonArray)
    {
        JObject parsed = JObject.Parse(json);
        Merge(result, parsed);
    }
    return result.ToString();
}

private static void Merge(JObject receiver, JObject donor)
{
    foreach (var property in donor)
    {
        JObject receiverValue = receiver[property.Key] as JObject;
        JObject donorValue = property.Value as JObject;
        if (receiverValue != null && donorValue != null)
            Merge(receiverValue, donorValue);
        else
            receiver[property.Key] = property.Value;
    }
}