JSON

.net 提取多层嵌套的JSON

字号+ 作者:H5之家 来源:H5之家 2017-05-26 09:02 我要评论( )

本文是对.net 提取多层嵌套的JSON的讲解,对学习ASP.NET编程技术有所帮助,与大家分享。

Newtonsoft.Json.Net20.dll 下载请访问

在.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();

 

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

相关文章
  • postgresql 从json数组中提取json值,并分组,汇总

    postgresql 从json数组中提取json值,并分组,汇总

    2017-01-29 09:00

  • API json多层数据实体类封装(利用泛型技术)

    API json多层数据实体类封装(利用泛型技术)

    2016-10-21 12:00

  • c#解析嵌套json

    c#解析嵌套json

    2016-03-11 12:00

  • 嵌套json数据解析,该如何处理

    嵌套json数据解析,该如何处理

    2016-01-17 15:01

网友点评