C#解析Json数据(利用Newtonsoft.Json库)

今天想做个快递查询软件玩玩,手头有个快递查询api,它返回的数据是Json,百度了一下如何用C#解析Json数据,终于慢慢理解。所以现在写篇日志记录一下。
本文章用到的类库: http://pan.baidu.com/s/1hqEOfli

当然你也可以到官网去下载。地址:http://www.newtonsoft.com/json


使用api返回类似以下数据,如果看不懂,可以先去看Json数据是如何组织的。

{
"status":"3",
"message":"",
"errCode":"0",
"data":[
	{"time":"2015-05-28 20:26","context":"福建省泉州市晋江市公司 已收件"},
	{"time":"2015-05-28 21:26","context":"福建省泉州市晋江市公司 已打包"},
	{"time":"2015-05-30 08:44","context":"广西省桂林市公司 已发出"},
	{"time":"2015-05-30 14:50","context":"广西省桂林市七星区育才路分部公司 派件中"},
	{"time":"2015-05-31 18:11","context":"广西省桂林市七星区育才路分部公司 已签收"}
],
"html":"",
"mailNo":"500151529838",
"expTextName":"圆通快递",
"expSpellName":"yuantong",
"update":"1433655616",
"cache":"0",
"ord":"ASC",
"tel":"95554"
}

我们下载好类库后,添加类库到引用

using Newtonsoft.Json;

然后写两个类实体,List对应Json的数组,类的成员名要和上面的Json数据一致。

public class JsonParser
{
public int status;
public int errCode;
public string message;
public string html;
public int mailTo;
public string tel;
public string expTextName;
public List data;
}
public class Data {
public string time;
public string context;
} 
上面的Json数据中,如果只想取data数据中的time字段和context字段的内容。可以这样写:
 //反序列化Json数据
JsonParser jp = (JsonParser)JsonConvert.DeserializeObject(result);//result为上面的Json数据
List list = jp.data;
list = jp.data;
StringBuilder sb = new StringBuilder();
foreach(Data data in list){
sb.Append(data.time+"\t");
sb.Append(data.context + "\r\n\r\n");
} 

上面的代码,如果打印sb.ToString()的结果就会打印出以下内容:

2015-05-28 20:26 福建省泉州市晋江市公司 已收件

2015-05-28 21:26 福建省泉州市晋江市公司 已打包

2015-05-30 08:44 广西省桂林市公司 已发出

2015-05-30 14:50 广西省桂林市七星区育才路分部公司 派件中

2015-05-31 18:11 广西省桂林市七星区育才路分部公司 已签收
说明我们解析成功了。
最后送上快递查询的源代码
链接:https://pan.baidu.com/s/1yPM8r33bWszIK6QCaOqamg 密码:6b0i

你可能感兴趣的:(c#,json,C#/.Net)