从JSON.net中的JArray中获取值

时间:2015-07-28 14:13:44

标签: c# json.net

我无法从JArray获取数据,特别是我正在尝试访问ID值。这是一个JSON示例

{
"page": 1,
"totalPages": 5,
"pageSize": 2,
"sortField": "label",
"sortOrder": "asc",
"content": [
  {
  "organizationId": "Org123",
  "id": "333",
  "label": "comp1"
  },
  {
  "organizationId": "Org123",
  "id": "444",
  "label": "comp2"
  }
]
}

这就是我在C#中所拥有的东西。

        JArray jArray = new JArray(jsonString);

        foreach (JValue item in jArray)
        {
            Console.WriteLine(item["id"]);
        } 

我知道我需要检查JValue以确保它是一个ID类型,但是我对在JArray中分解的对象类型感到困惑。

1 个答案:

答案 0 :(得分:6)

首先,您要处理顶级对象。解析对象后,需要查看content数组:

var obj = JObject.Parse(json);

foreach (JObject element in obj["content"])
{
    Console.WriteLine(element["id"]);
}

以下是https://dotnetfiddle.net/DhVZFf

另外(这可能只是一个错字),你的JSON格式不正确。具体来说,content数组中的逗号分隔元素位置错误:

{
    "organizationId": "Org123",
    "id": "333",
    "label": "comp1", // <---
}
{
  "organizationId": "Org123",
  "id": "444",
  "label": "comp2",
}

这些逗号应该在数组元素之间

{
    "organizationId": "Org123",
    "id": "333",
    "label": "comp1"
}, // <---
{
  "organizationId": "Org123",
  "id": "444",
  "label": "comp2"
}