And*_*art 0 c# arrays parsing json list
所以在做了一个Web请求后,我得到了这个JSON字符串:
{"status":"okay","result":[{"id":8810,"country":"IE","region":"07","city":"Dublin","latitude":53.3331,"longitude":-6.2489,"comment":"407367 donkeys"},{"id":9688,"country":"IE","region":"04","city":"Cork","latitude":51.8986,"longitude":-8.4958,"comment":"454765 donkeys"},{"id":9963,"country":"IE","region":"06","city":"Donegal","latitude":54.65,"longitude":-8.1167,"comment":"315518 donkeys"}]}
Run Code Online (Sandbox Code Playgroud)
我不确定如何解析它.我有一个具有id,country,region等的City类,我希望能够在列表中单独保存每个类,这样我就可以将它们添加到应用程序的列表视图中.
我试过这个:
JObject jobj = JObject.Parse(jsonString);
JToken jstatus = jobj["status"];
JToken jresult = jobj["result"];
status = (String)jstatus;
JArray arrayOfCities = JArray.Parse(jsonString);
if (status.Equals("okay"))
{
foreach (JObject o in arrayOfCities.Children<JObject>())
{
foreach (JProperty p in o.Properties())
{
id = p.Name + p.Value.ToString();// (String)jresult["id"];
country = (String)jresult["country"];
region = (String)jresult["region"];
city = (String)jresult["city"];
latitude = (String)jresult["latitude"];
longitude = (String)jresult["longitude"];
comment = (String)jresult["comment"];
}
}
}
Run Code Online (Sandbox Code Playgroud)
但是我不断收到解析错误.我尝试了一些东西,但没有一个最终起作用.我如何分别解析数组的每个部分并将其保存到城市列表.谢谢
你应该用DeserializeObject
.这是一个例子:
public class CitiesResponse
{
public string Status { get; set; }
public List<City> Result { get; set; }
}
var response = JsonConvert.DeserializeObject<CitiesResponse>(jsonString);
// response.Result is your list of cities
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
227 次 |
最近记录: |