2012-06-21 92 views
27

我在C#中使用JSON.NET來解析來自Klout API的響應。我的回覆是這樣的:在C#中迭代JSON對象#

[ 
    { 
    "id": "5241585099662481339", 
    "displayName": "Music", 
    "name": "music", 
    "slug": "music", 
    "imageUrl": "http://kcdn3.klout.com/static/images/music-1333561300502.png" 
    }, 
    { 
    "id": "6953585193220490118", 
    "displayName": "Celebrities", 
    "name": "celebrities", 
    "slug": "celebrities", 
    "imageUrl": "http://kcdn3.klout.com/static/images/topics/celebrities_b32741b6703151cc7bd85fba24c44c52.png" 
    }, 
    { 
    "id": "5757029936226020304", 
    "displayName": "Entertainment", 
    "name": "entertainment", 
    "slug": "entertainment", 
    "imageUrl": "http://kcdn3.klout.com/static/images/topics/Entertainment_7002e5d2316e85a2ff004fafa017ff44.png" 
    }, 
    { 
    "id": "3718", 
    "displayName": "Saturday Night Live", 
    "name": "saturday night live", 
    "slug": "saturday-night-live", 
    "imageUrl": "http://kcdn3.klout.com/static/images/icons/generic-topic.png" 
    }, 
    { 
    "id": "8113008320053776960", 
    "displayName": "Hollywood", 
    "name": "hollywood", 
    "slug": "hollywood", 
    "imageUrl": "http://kcdn3.klout.com/static/images/topics/hollywood_9eccd1f7f83f067cb9aa2b491cd461f3.png" 
    } 
] 

如您所見,它包含5個id標籤。也許下次它會是6或1或其他數字。我想迭代JSON並獲取每個id標記的值。不知道會有多少人,我無法運行循環。我該如何解決這個問題?

回答

55
dynamic dynJson = JsonConvert.DeserializeObject(json); 
foreach (var item in dynJson) 
{ 
    Console.WriteLine("{0} {1} {2} {3}\n", item.id, item.displayName, 
     item.slug, item.imageUrl); 
} 

var list = JsonConvert.DeserializeObject<List<MyItem>>(json); 

public class MyItem 
{ 
    public string id; 
    public string displayName; 
    public string name; 
    public string slug; 
    public string imageUrl; 
} 
+0

它說,失蹤參考Micrsofot.CSHARp和System.Core.I添加參考both.It的APS.NET應用 –

+2

不幸的是「動態」的關鍵字可從框架4.0起:( –

15

可以使用JsonTextReader讀取JSON和迭代標記:

using (var reader = new JsonTextReader(new StringReader(jsonText))) 
{ 
    while (reader.Read()) 
    { 
     Console.WriteLine("{0} - {1} - {2}", 
          reader.TokenType, reader.ValueType, reader.Value); 
    } 
} 
+2

雖然不是必需的,這是唯一的答案,允許您在事先不知道結構的情況下遍歷JObject –

+1

這是一個非常好的答案,它提供了對解析的JSON進行完全控制的選項。非常有用,謝謝! – Zoran

0

這個工作對我來說,轉換爲嵌套JSON來容易閱讀YAML

string JSONDeserialized {get; set;} 
    public int indentLevel; 

    private bool JSONDictionarytoYAML(Dictionary<string, object> dict) 
    { 
     bool bSuccess = false; 
     indentLevel++; 

     foreach (string strKey in dict.Keys) 
     { 
      string strOutput = "".PadLeft(indentLevel * 3) + strKey + ":"; 
      JSONDeserialized+="\r\n" + strOutput; 

      object o = dict[strKey]; 
      if (o is Dictionary<string, object>) 
      { 
       JSONDictionarytoYAML((Dictionary<string, object>)o); 
      } 
      else if (o is ArrayList) 
      { 
       foreach (object oChild in ((ArrayList)o)) 
       { 
        if (oChild is string) 
        { 
         strOutput = ((string)oChild); 
         JSONDeserialized += strOutput + ","; 
        } 
        else if (oChild is Dictionary<string, object>) 
        { 
         JSONDictionarytoYAML((Dictionary<string, object>)oChild); 
         JSONDeserialized += "\r\n"; 
        } 
       } 
      } 
      else 
      { 
       strOutput = o.ToString(); 
       JSONDeserialized += strOutput; 
      } 
     } 

     indentLevel--; 

     return bSuccess; 

    } 

使用

 Dictionary<string, object> JSONDic = new Dictionary<string, object>(); 
     JavaScriptSerializer js = new JavaScriptSerializer(); 

      try { 

      JSONDic = js.Deserialize<Dictionary<string, object>>(inString); 
      JSONDeserialized = ""; 

      indentLevel = 0; 
      DisplayDictionary(JSONDic); 

      return JSONDeserialized; 

     } 
     catch (Exception) 
     { 
      return "Could not parse input JSON string"; 
     }