asp.net提取多层嵌套json数据的方法

Thadea ·
更新时间:2024-11-13
· 972 次阅读

本文实例讲述了asp.net提取多层嵌套json数据的方法。分享给大家供大家参考,具体如下:

在.net 2.0中提取这样的json:
代码如下:{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}}

引用命名空间:

using Newtonsoft.Json; using Newtonsoft.Json.Linq;

可以把上面的JSON看成一个对象.你只要写对应的类即可

public class UserInfo { public string name; public int age; public address addr; } public class address { public string city; public string province; }

然后在解析的地方这样写:

string jsonData="{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":guangzhou,\"province\":guangdong}}"; UserInfo user=(UserInfo)JsonConvert.DeserializeObject(jsonData, typeof(UserInfo));

得到City的值只要:user.addr.City;

这样实现也行

JObject jsonObj = JObject.Parse(jsonData); string name=jsonObj ["name"].ToString(); string age=jsonObj ["age"].ToString(); string city=((JObject )jsonObj ["addr"])["city"].ToString(); string province=((JObject )jsonObj ["addr"])["province"].ToString();

如何这个json是动态的呢?譬如让你输入一个json,如
代码如下:{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}};

然后让你输入一个对象,如city,然后系统会输出guangzhou这个值,那这样的话,json就是动态生成的了,我想了解有没有读取这样的json的方法。(注意,json是多级嵌套的。)

就用遍历

public string GetJsonValue(JEnumerable<JToken> jToken,string key) { IEnumerator enumerator = jToken.GetEnumerator(); while (enumerator.MoveNext()) { JToken jc = (JToken)enumerator.Current; if (jc is JObject||((JProperty)jc).Value is JObject) { return GetJsonValue(jc.Children(), key); } else { if (((JProperty)jc).Name == key) { return ((JProperty)jc).Value.ToString(); } } } return null; }

在调用的时候:

string jsonData = "{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":\"guangzhou\",\"province\":\"guangdong\"}}"; JObject jsonObj = JObject.Parse(jsonData); Response.Write(GetJsonValue(jsonObj.Children(), "province"));

如果有多层嵌套的数组

string jsonData = "{\"addr\":[{\"city\":\"guangzhou\",\"province\":\"guangdong\"},{\"city\":\"guiyang\",\"province\":\"guizhou\"}]}"; JObject jsonObj = JObject.Parse(jsonData); JArray jar = JArray.Parse(jsonObj["addr"].ToString()); JObject j = JObject.Parse(jar[0].ToString()); Response.Write(j["city"]);

JSON转XML:
代码如下:string xmlstr=((XmlDocument)JsonConvert.DeserializeXmlNode(jsonData)).InnerXml.ToString();

PS:关于json格式数据操作小编这里推荐几款本站的在线工具供大家免费使用,相信在以后的开发中可以派上用场:

在线JSON代码检验、检验、美化、格式化工具:
http://tools.jb51.net/code/json

在线XML/JSON互相转换工具:
http://tools.jb51.net/code/xmljson

C语言风格/HTML/CSS/json代码格式化美化工具:
http://tools.jb51.net/code/ccode_html_css_json

json代码在线格式化/美化/压缩/编辑/转换工具:
http://tools.jb51.net/code/jsoncodeformat

更多关于asp.net相关内容感兴趣的读者可查看本站专题:《asp.net操作json技巧总结》、《asp.net字符串操作技巧汇总》、《asp.net操作XML技巧总结》、《asp.net文件操作技巧汇总》、《asp.net ajax技巧总结专题》及《asp.net缓存操作技巧总结》。

希望本文所述对大家asp.net程序设计有所帮助。

您可能感兴趣的文章:使用jQuery向asp.net Mvc传递复杂json数据-ModelBinder篇使用ASP.NET一般处理程序或WebService返回JSON的实现代码asp.net(C#)解析Json的类代码asp.net JSONHelper JSON帮助类Jquery 组合form元素为json格式,asp.net反序列化asp.net+jquery Jsonp使用方法Jquery中getJSON在asp.net中的使用说明ASP.NET JSON字符串与实体类的互转换示例代码jQuery+ajax+asp.net获取Json值的方法解决Asp.net Mvc返回JsonResult中DateTime类型数据格式问题的方法asp.net使用DataTable构造Json字符串的方法ASP.NET中XML转JSON的方法实例



ASP

需要 登录 后方可回复, 如果你还没有账号请 注册新账号