asp.net提取多層嵌套json資料的方法_實用技巧

來源:互聯網
上載者:User

本文執行個體講述了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程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.