c# - 合并 2 个 JSON 文件 Newtonsoft

标签 c# .net json visual-studio json.net

我有 2 个 json 文件或字符串,我想根据 ID 合并它们。就像加入 sql 一样。这是示例:

这是 Json 1:

{
    "City": [{
        "CityId": 9,
        "CityName": "Kukes"
    }, {
        "CityId": 18,
        "CityName": "Tirana"
    }, {
        "CityId": 19,
        "CityName": "Vlore"
    }, {
        "CityId": 22,
        "CityName": "temp"
    }]
}

这是我的 json 2:

{
    "Citizen": [{
        "CitizenId": 38,
        "CitizenLastName": "Bale",
        "CitizenName": "Christian",
        "City_Id": 19
    }, {
        "CitizenId": 39,
        "CitizenLastName": "ttrtrt",
        "CitizenName": "test",
        "City_Id": 18
    }, {
        "CitizenId": 42,
        "CitizenLastName": "Freeman",
        "CitizenName": "Morgan",
        "City_Id": 9
    }, {
        "CitizenId": 43,
        "CitizenLastName": "Snow",
        "CitizenName": "Jon",
        "City_Id": 9
    }, {
        "CitizenId": 44,
        "CitizenLastName": "test2",
        "CitizenName": "test",
        "City_Id": 9
    }]
}

我希望它合并到一个基于 id 的 json 文件或字符串中,如下所示:

{
    "City":
    [
        {
            "CityId":9,
            "CityName":"Kukes",
            "Citizens" : [{"CitizenId":42,"CitizenLastName":"Freeman","CitizenName":"Morgan","City_Id":9},{"CitizenId":43,"CitizenLastName":"Snow","CitizenName":"Jon","City_Id":9},{"CitizenId":44,"CitizenLastName":"test2","CitizenName":"test","City_Id":9}]
        },
        {
            "CityId":18,
            "CityName":"Tirana",
            "Citizens" : [{"CitizenId":39,"CitizenLastName":"ttrtrt","CitizenName":"test","City_Id":18}]
        },
        {
            "CityId":19,
            "CityName":"Vlore",
            "Citizens" : [{"CitizenId":38,"CitizenLastName":"Bale","CitizenName":"Christian","City_Id":19}]
        },
        {
            "CityId":22,
            "CityName":"temp",
            "Citizens" : []
        }
    ]
}

我试了一整天,还是一无所获。你知道如何用 Newtonsoft 做到这一点吗?还是有其他办法?但我希望使用 newtonsoft。

最佳答案

您可以使用 LINQ to JSON 执行此操作, 使用 ToLookup()查找给定城市的所有公民:

var cities = JToken.Parse(cityJson);
var citizens = JToken.Parse(citizenJson);

var lookup = citizens.SelectTokens("Citizen[*]").ToLookup(c => (string)c["City_Id"]);

foreach (var city in cities.SelectTokens("City[*]"))
{
    city["Citizens"] = new JArray(lookup[(string)city["CityId"]]);
}

原型(prototype) fiddle .

要从文件加载 JSON,然后再保存回来,请参阅 Read JSON from a fileWrite JSON to a file .

关于c# - 合并 2 个 JSON 文件 Newtonsoft,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36651961/

相关文章:

C# 继承和成员隐藏

c# - 遍历一个对象并找到非空属性

c# - Convert.ToDouble() 抛出格式异常

javascript - 将 JSON 文件中的数据绑定(bind)到 Angular 2 View

javascript - JSON.parse 解析 JSON.stringify 输出,但不解析字符串本身

json - 在 Dart 中将 Map 的所有键和值转换为 String

c# - 类型成员的表达式导致不同的表达式(MemberExpression、UnaryExpression)

c# - 如果您在任务管理器中结束进程,GC 是否仍会清理?

c# - 转换日期时间时区以进行显示的正确方法

c# - 为什么 Entity Framework 实体是部分类?