JSON

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

字号+ 作者:H5之家 来源:H5之家 2017-08-19 17:04 我要评论( )

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

本文实例讲述了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代码检验、检验、美化、格式化工具:

在线XML/JSON互相转换工具:

C语言风格/HTML/CSS/json代码格式化美化工具:

json代码在线格式化/美化/压缩/编辑/转换工具:

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

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

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • Asp.net MVC Razor模板引擎技巧分享

    Asp.net MVC Razor模板引擎技巧分享

    2017-08-09 10:00

  • “Newtonsoft.Json ......”在这两个“混合\ Newtonsoft.Json.dl

    “Newtonsoft.Json ......”在这两个“混合\ Newtonsoft.Json.dl

    2017-07-29 13:03

  • ASP.NET MVC解决Json DataGrid返回的日期格式是/Date(20130450000365)

    ASP.NET MVC解决Json DataGrid返回的日期格式是/Date(20130450000365

    2017-07-15 10:00

  • 痴情意外:ASP.NET WebAPI RC 竟然不支持最常用的json传参

    痴情意外:ASP.NET WebAPI RC 竟然不支持最常用的json传参

    2017-07-08 10:02

网友点评