2013-03-11 61 views
1

我想從我的linq響應中返回地址信息。我很接近,但無法得到最後一刻。我需要每個條目的所有地址信息。使用JSON.NET和數組解析JSON響應&LINQ

有人可以協助最後一點嗎?

var allCentres = from p in obj["early_child_centres"] 
      select p["address"].Children(); 

      foreach (var item in allCentres) 
      { 
       Console.WriteLine(item); 
      } 

{ 

"early_child_centres": [ 
{ 

    "centre_name": "Arncliffe Early Childhood Centre", 

    "address": { 
    "street_name": "12 Firth St", 
    "suburb": "Arncliffe", 
    "state": "NSW", 
    "postcode": "2205", 
    "phone": "9599 2896" 
    }, 
    "special_notes": "", 

}, 

] 
} 

回答

2

您可以使用實體反序列化JSON:

[DataContract] 
public class Center 
{ 
    [DataMember(Name = "center_name")] 
    public string Name { get; set; } 
    [DataMember(Name = "special_notes")] 
    public string SpecialNotes { get; set; } 
    [DataMember(Name = "address")] 
    public Address Address { get; set; } 

    public Center() { this.Address = new Address();} 
} 

[DataContract] 
public class Address 
{ 
    [DataMember(Name = "street_name")] 
    public string StreetName { get; set; } 
    [DataMember(Name = "suburb")] 
    public string Suburb { get; set; } 
    [DataMember(Name = "state")] 
    public string State { get; set; } 
    [DataMember(Name = "postcode")] 
    public string Postcode { get; set; } 
    [DataMember(Name = "phone")] 
    public string Phone { get; set; } 
} 

並與反序列化:

List<Center> centers = JsonConvert.DeserializeObject<List<Center>>(obj["early_child_centres"].ToString()); 

然後,你的LINQ要求:

from c in center 
select c.Address 
+0

嗨喬佛裏,謝謝你爲我提供這樣一個簡潔而完整的答案。它像一種享受。 – user686483 2013-03-16 01:35:01