Разбор JSON, содержащий неназванный узел - PullRequest
0 голосов
/ 24 мая 2018

У меня есть следующая полезная нагрузка JSON.

Задача состоит в том, чтобы получить значение имени и соответствующий номер корневого узла (3925 или 3932), поскольку этот узел не назван.

Я использую C #

"3925": {
        "totalExecutions": 2,
        "endDate": "",
        "description": "",
        "totalExecuted": 2,
        "started": "",
        "versionName": "Custom Pipes Development",
        "expand": "executionSummaries",
        "projectKey": "WUSDV007",
        "versionId": 22361,
        "environment": "",
        "totalCycleExecutions": 2,
        "totalDefects": 0,
        "build": "",
        "createdBy": "mghosh",
        "ended": "",
        "name": "SetMaxFutureDateFromCustomerField_Mobile",
        "totalFolders": 0,
        "modifiedBy": "mghosh",
        "projectId": 17101,
        "createdByDisplay": "Mayukh Ghosh",
        "startDate": "",
        }
    }

"3932": {
        "totalExecutions": 2,
        "endDate": "",
        "description": "",
        "totalExecuted": 2,
        "started": "",
        "versionName": "Custom Pipes Development",
        "expand": "executionSummaries",
        "projectKey": "WUSDV007",
        "versionId": 22361,
        "environment": "",
        "totalCycleExecutions": 2,
        "totalDefects": 0,
        "build": "",
        "createdBy": "nkonda",
        "ended": "",
        "name": "WUSDV007-29779-Fee Validation",
        "totalFolders": 0,
        "modifiedBy": "nkonda",
        "projectId": 17101,
        "createdByDisplay": "Naveen Kumar Konda",
        "startDate": "",

    }

Любые предложения высоко ценятся.

1 Ответ

0 голосов
/ 24 мая 2018

Попробуйте код следующим образом:

string jsonString = "{\"3925\": { \"totalExecutions\": 2, \"endDate\": \"\", \"description\": \"\", \"totalExecuted\": 2, \"started\": \"\", \"versionName\": \"Custom Pipes Development\", \"expand\": \"executionSummaries\", \"projectKey\": \"WUSDV007\", \"versionId\": 22361, \"environment\": \"\", \"totalCycleExecutions\": 2, \"totalDefects\": 0, \"build\": \"\", \"createdBy\": \"mghosh\", \"ended\": \"\", \"name\": \"SetMaxFutureDateFromCustomerField_Mobile\", \"totalFolders\": 0, \"modifiedBy\": \"mghosh\", \"projectId\": 17101, \"createdByDisplay\": \"Mayukh Ghosh\", \"startDate\": \"\" }}";

var parameters = JObject.Parse(jsonString);

foreach (var item in parameters.OfType<JProperty>())
{
   var innerObject = JObject.Parse(item.Value.ToString());
   Console.WriteLine(innerObject.ToString());
}
...