Удалите все вхождения определенного ключа из ответа JSON в C#

У меня есть строка JSON, из которой я хочу исключить все вхождения данного ключа.

JSON у меня есть:

string requstBody =       
{
              "payLoad": [
                {
                  "BaseVersionId_": 9,
                  "VersionId_": 10,              
                  "AssetCollateralLink": [
                    {
                      "AssetId": 137,
                      "BaseVersionId_": 9,
                      "VersionId_": 10
                    },
                    {
                      "AssetId": 136,
                      "BaseVersionId_": 0,
                      "VersionId_": 1
                    }
                  ],
                  "CollateralProvider": [],
                  "AdvCollateralAllocation": [
                    {
                      "LinkId": 91,
                      "IsDeleted_": false,
                      "BaseVersionId_": 1,
                      "VersionId_": 2
                    }
                  ]
                }
              ]
            }

Я хочу удалить ключи "BaseVersionID_" и "VersionId_" следующим образом:

  string requstBody =  
{
              "payLoad": [
                {
                  "AssetCollateralLink": [
                    {
                      "AssetId": 137
                    },
                    {
                      "AssetId": 136
                    }
                  ],
                  "CollateralProvider": [],
                  "AdvCollateralAllocation": [
                    {
                      "LinkId": 91,
                      "IsDeleted_": false
                    }
                  ]
                }
              ]
            }

Я использовал JObject.Remove(); следующим образом

JObject sampleObj1 = new JObject();
sampleObj1 = JsonHelper.JsonParse(requestBody);
sampleObj1.Remove("BaseVersionId_");

но может удалить ключи только в иерархии payLoad. Как удалить все вхождения ключа.

2 ответа

Я бы использовал JsonPath как таковой:

var toRemove =  jsonObject
                .SelectTokens("$.payLoad.[*].AssetCollateralLink.[*]..BaseVersionId_")
                .Concat(stuff.SelectTokens("$.payLoad.[*].AssetCollateralLink.[*]..VersionId_"))
                .Concat(stuff.SelectTokens("$.payLoad.[*].AdvCollateralAllocation.[*]..VersionId_"))
                .Concat(stuff.SelectTokens("$.payLoad.[*].AdvCollateralAllocation.[*]..BaseVersionId_"))
                .ToList();

for (int i = toRemove.Count - 1; i >= 0; i--)
{
    toRemove[i].Parent?.Remove();
}

Требуемые свойства можно удалить из Json, просто с помощью Linq:

var jsonObj = JObject.Parse(requestBody);
jsonObj.SelectToken("payLoad[0]").SelectToken("AdvCollateralAllocation")
                .Select(jt => (JObject)jt)
                .ToList()
                .ForEach(r =>
                    r
                    .Properties()
                    .ToList()
                    .ForEach(e =>
                    {
                        if (e.Name == "BaseVersionId_" || e.Name == "VersionId_")
                            e.Remove();
                    }));

Результирующий jsonObj будет без BaseVersionId_ а также VersionId_ имена, а также их значения.

Другие вопросы по тегам