主頁(yè) > 知識(shí)庫(kù) > asp.net提取多層嵌套json數(shù)據(jù)的方法

asp.net提取多層嵌套json數(shù)據(jù)的方法

熱門(mén)標(biāo)簽:西寧呼叫中心外呼系統(tǒng)線路商 外呼電話機(jī)器人成本 地圖標(biāo)注軟件免費(fèi)下載 百應(yīng)電話機(jī)器人外呼系統(tǒng) 聯(lián)通官網(wǎng)400電話辦理 蘇州如何辦理400電話 400電話辦理怎么樣 網(wǎng)絡(luò)電話外呼系統(tǒng)上海 臨沂智能電話機(jī)器人加盟

本文實(shí)例講述了asp.net提取多層嵌套json數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:

在.net 2.0中提取這樣的json:

復(fù)制代碼 代碼如下:
{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}}

引用命名空間:

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

可以把上面的JSON看成一個(gè)對(duì)象.你只要寫(xiě)對(duì)應(yīng)的類(lèi)即可

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

然后在解析的地方這樣寫(xiě):

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

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

這樣實(shí)現(xiàn)也行

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

如何這個(gè)json是動(dòng)態(tài)的呢?譬如讓你輸入一個(gè)json,如

復(fù)制代碼 代碼如下:
{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}};

然后讓你輸入一個(gè)對(duì)象,如city,然后系統(tǒng)會(huì)輸出guangzhou這個(gè)值,那這樣的話,json就是動(dòng)態(tài)生成的了,我想了解有沒(méi)有讀取這樣的json的方法。(注意,json是多級(jí)嵌套的。)

就用遍歷

public string GetJsonValue(JEnumerableJToken> 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)用的時(shí)候:

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"]);

JSON轉(zhuǎn)XML:

復(fù)制代碼 代碼如下:
string xmlstr=((XmlDocument)JsonConvert.DeserializeXmlNode(jsonData)).InnerXml.ToString();

PS:關(guān)于json格式數(shù)據(jù)操作小編這里推薦幾款本站的在線工具供大家免費(fèi)使用,相信在以后的開(kāi)發(fā)中可以派上用場(chǎng):

在線JSON代碼檢驗(yàn)、檢驗(yàn)、美化、格式化工具:
http://tools.jb51.net/code/json

在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson

C語(yǔ)言風(fēng)格/HTML/CSS/json代碼格式化美化工具:
http://tools.jb51.net/code/ccode_html_css_json

json代碼在線格式化/美化/壓縮/編輯/轉(zhuǎn)換工具:
http://tools.jb51.net/code/jsoncodeformat

更多關(guān)于asp.net相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《asp.net操作json技巧總結(jié)》、《asp.net字符串操作技巧匯總》、《asp.net操作XML技巧總結(jié)》、《asp.net文件操作技巧匯總》、《asp.net ajax技巧總結(jié)專(zhuān)題》及《asp.net緩存操作技巧總結(jié)》。

希望本文所述對(duì)大家asp.net程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • 使用jQuery向asp.net Mvc傳遞復(fù)雜json數(shù)據(jù)-ModelBinder篇
  • 使用ASP.NET一般處理程序或WebService返回JSON的實(shí)現(xiàn)代碼
  • asp.net(C#)解析Json的類(lèi)代碼
  • asp.net JSONHelper JSON幫助類(lèi)
  • Jquery 組合form元素為json格式,asp.net反序列化
  • asp.net+jquery Jsonp使用方法
  • Jquery中g(shù)etJSON在asp.net中的使用說(shuō)明
  • ASP.NET JSON字符串與實(shí)體類(lèi)的互轉(zhuǎn)換示例代碼
  • jQuery+ajax+asp.net獲取Json值的方法
  • 解決Asp.net Mvc返回JsonResult中DateTime類(lèi)型數(shù)據(jù)格式問(wèn)題的方法
  • asp.net使用DataTable構(gòu)造Json字符串的方法
  • ASP.NET中XML轉(zhuǎn)JSON的方法實(shí)例

標(biāo)簽:海西 甘肅 清遠(yuǎn) 慶陽(yáng) 中衛(wèi) 聊城 臨夏

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net提取多層嵌套json數(shù)據(jù)的方法》,本文關(guān)鍵詞  asp.net,提取,多層,嵌套,json,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《asp.net提取多層嵌套json數(shù)據(jù)的方法》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于asp.net提取多層嵌套json數(shù)據(jù)的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章