詳解ASP.NET提取多層嵌套json數(shù)據(jù)的方法
本文實(shí)例講述了ASP.NET利用第三方類庫Newtonsoft.Json提取多層嵌套json數(shù)據(jù)的方法,具體例子如下。
假設(shè)需要提取的json字符串如下:
{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}}
先引用命名空間:
using Newtonsoft.Json; using Newtonsoft.Json.Linq;
可以把上面的json字符串看成一個對象,只要編寫對應(yīng)的類即可(如果使用VS2013進(jìn)行開發(fā),可以通過“編輯--選擇性粘貼--將JSON粘貼為類”快速地將json字符串轉(zhuǎn)換為實(shí)體類)
public class UserInfo { public string name; public int age; public address addr; } public class address { public string city; public string province; }
1、將json字符串轉(zhuǎn)換為實(shí)體對象的代碼如下:
string jsonData="{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":guangzhou,\"province\":guangdong}}"; UserInfo user=(UserInfo)JsonConvert.DeserializeObject(jsonData, typeof(UserInfo));
2、讀取json中某個屬性的值可以使用一下代碼:
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();
3、解釋多層嵌套json,獲取任意屬性的值:
如果需要處理的json字符串如下:
{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}};
然后讓你輸入一個對象,如“city”,系統(tǒng)就會輸出“guangzhou”,輸入“age”,就輸出“23”。由于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; }
調(diào)用GetJsonValue的代碼:
string jsonData = "{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":\"guangzhou\",\"province\":\"guangdong\"}}"; JObject jsonObj = JObject.Parse(jsonData); Response.Write(GetJsonValue(jsonObj.Children(), "province"));
如果是多層嵌套的數(shù)組,也可以使用以下代碼:
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"]);
4、JSON轉(zhuǎn)XML:
string xmlstr=((XmlDocument)JsonConvert.DeserializeXmlNode(jsonData)).InnerXml.ToString();
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
一步步打造簡單的MVC電商網(wǎng)站BooksStore(3)
這篇文章主要和大家一起一步步打造一個簡單的MVC電商網(wǎng)站,MVC電商網(wǎng)站BooksStore第三篇,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04ASP.NET抓取網(wǎng)頁內(nèi)容的實(shí)現(xiàn)方法
這篇文章主要介紹了ASP.NET抓取網(wǎng)頁內(nèi)容的實(shí)現(xiàn)方法,涉及使用HttpWebRequest及WebResponse抓取網(wǎng)頁內(nèi)容的技巧,需要的朋友可以參考下2015-02-02asp.net+jquery ajax無刷新登錄的實(shí)現(xiàn)方法
asp.net+jquery ajax無刷新登錄的實(shí)現(xiàn)方法,需要的朋友可以參考一下2013-06-06Asp.Net MVC學(xué)習(xí)總結(jié)之過濾器詳解
本篇文章主要介紹了Asp.Net MVC學(xué)習(xí)總結(jié)之過濾器詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03asp.net中不能在DropDownList中選擇多個項 原因分析及解決方法
不能在 DropDownList 中選擇多個項,在前一步操作的過程中,已經(jīng)選擇了某個Item2012-10-10System.Data.SqlClient.SqlException: 無法打開登錄所請求的數(shù)據(jù)庫 登錄失敗。
今天幫客戶配置服務(wù)器的時間,安全設(shè)置后,將sqlserver以普通用戶權(quán)限運(yùn)行的時候提示這個錯誤。2011-08-08