1. 程式人生 > >提取多層巢狀Json資料

提取多層巢狀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();

MSCL超強工具類庫

←左側掃碼購買或聯絡QQ7400799(備註:MSCL)購買原始碼   

是基於C#開發的超強工具類集合,涵蓋了日常B/S或C/S開發的諸多方面,包含上百個常用封裝類(資料庫操作類全面支援Mysql、Access、Oracle、Sqlserver、Sqlite等資料庫,常用字串處理類,記憶體容器類,Session/Cookie/Cache類,Config配置檔案幫助類,資料型別轉換類,進位制轉換類,時間日期幫助類,資料加密解密類,檔案/目錄操作類,檔案下載類,FTP操作類,圖片上傳/下載類,圖片常用處理類-翻轉,模糊,水印,縮略等,Json輔助類,Log日誌類,Http封裝類,Email郵件封裝類,NOPI操作類-無依賴Office元件實現execl匯入匯出利器,Execl/CSV操作類,Until常用工具類,資料分頁類,遠端採集類,JS封裝類,Reg正則驗證類,Request請求類,隨機數生成類,序列化反序列化封裝類,XML操作類,ZIP壓縮和解壓類等等等。。。此處省略一萬字),即拿即用,封裝類附帶呼叫示例和引數註釋,全傻瓜式呼叫,簡單易用。擁有此超強工具類,能大大的提高C#開發人員的效率和程式碼質量,真正做到“工具在手,一有盡有”,讓苦逼的廣大程式猿朋友,早日脫離苦海,暢遊在程式碼的世界裡 ^_^