C# 解析 json
JSON(全稱為JavaScript Object Notation) 是一種輕量級的資料交換格式。它是基於JavaScript語法標準的子集。 JSON採用完全獨立於語言的文字格式,可以輕鬆在各種網路、平台和程式之間傳輸。 JSON的語法很簡單,易於閱讀和編寫,同時也易於機器解析和生成。
JSON與XML的比較
◆可讀性
JSON和XML的可讀性相比較而言,由於XML提供輔助的標籤,更適合人閱讀和理解。
◆檔案大小與傳輸
XML允許使用方便的標籤,所以檔案尺寸是要比JSON大的。而且JSON源自於Javascript,所以天生的主戰場是Javascript與網絡,在這裡,JSON有著XML無法追趕的優勢。
JSON語法
1. JSON 語法是 JavaScript 物件表示法語法的子集。
•資料在名稱/值對中:名稱是字串,使用雙引號表示。數值可以是:數字(整數或浮點數),字串(在雙引號中),陣列(在方括號中),物件(在花括號中),true/false/null。
•資料以逗號分隔:
•花括號保存物件:物件可以包含各種數據,包括陣列。
•方括號保存陣列:數字可以包含物件。
例如:
{ "employees": [ { "firstName": "Bill", "lastName": "Gates" }, { "firstName": "George", "lastName": "Bush" } ] }
2. 如果JSON中含有轉義字符,則需要轉義。例如檔案路徑中需要使用"\"而不是""。例如:{ "file":"C:\a.txt"}。
.NET操作JSON
JSON檔案讀入到記憶體中就是字串,.NET操作JSON就是產生與解析JSON字串。操作JSON通常有以下幾種方式:
1. 原始方式:自己按照JSON的語法格式,寫程式碼直接操作JSON字串。如非必要,應該很少人會走這條路,從頭再來的。
2. 通用方式【★★★★★】:
這種方式是使用開源的類別庫Newtonsoft.Json(下載地址http://json.codeplex.com/)。下載後加入工程就能用。通常可以使用JObject, JsonReader, JsonWriter處理。這種方式最通用,也最靈活,可以隨時修改不爽的地方。
(1)使用JsonReader讀取Json字串:
string jsonText = @"{""input"" : ""value"", ""output"" : ""result""}"; JsonReader reader = new JsonTextReader(new StringReader(jsonText)); while (reader.Read()) { Console.WriteLine(reader.TokenType + "\t\t" + reader.ValueType + "\t\t" + reader.Value); }
(2)使用JsonWriter寫字串:
StringWriter sw = new StringWriter(); JsonWriter writer = new JsonTextWriter(sw); writer.WriteStartObject(); writer.WritePropertyName("input"); writer.WriteValue("value"); writer.WritePropertyName("output"); writer.WriteValue("result"); writer.WriteEndObject(); writer.Flush(); string jsonText = sw.GetStringBuilder().ToString(); Console.WriteLine(jsonText);
(3)使用JObject讀取寫字串:
JObject jo = JObject.Parse(jsonText); string[] values = jo.Properties().Select(item => item.Value.ToString()).ToArray();
(4)使用JsonSerializer使用JObject讀取寫字串:
string jsonArrayText1 = "[{'a':'a1','b':'b1'},{'a':'a2','b':'b2'}]"; JArray ja = (JArray)JsonConvert.DeserializeObject(jsonArrayText1); string ja1a = ja[1]["a"].ToString(); //或者 JObject o = (JObject)ja[1]; string oa = o["a"].ToString();
(4)使用JsonSerializer與JsonReader):
數組型資料
string jsonText = "{\"beijing\":{\"zone\":\"海淀\",\"zone_en\":\"haidian\"}}"; JObject jo = (JObject)JsonConvert.DeserializeObject(jsonText); string zone = jo["beijing"]["zone"].ToString(); string zone_en = jo["beijing"]["zone_en"].ToString();
嵌套格式
Project p = new Project() { Input = "stone", Output = "gold" }; JsonSerializer serializer = new JsonSerializer(); StringWriter sw = new StringWriter(); serializer.Serialize(new JsonTextWriter(sw), p); Console.WriteLine(sw.GetStringBuilder().ToString()); StringReader sr = new StringReader(@"{""Input"":""stone"", ""Output"":""gold""}"); Project p1 = (Project)serializer.Deserialize(new JsonTextReader(sr), typeof(Project)); Console.WriteLine(p1.Input + "=>" + p1.Output);
自訂類別Project
class Project { public string Input { get; set; } public string Output { get; set; } }
上面的程式碼都是基於下面這個Project類別定義:
此外的話,說明是我們自己修改過的類,換成你們自己的相關類就可以了,不影響使用。 3. 內建方式:使用.NET Framework 3.5/4.0中提供的System.Web.Script.Serialization命名空間下的JavaScriptSerializer類別進行物件的序列化與反序列化,很直接。Project p = new Project() { Input = "stone", Output = "gold" }; JavaScriptSerializer serializer = new JavaScriptSerializer(); var json = serializer.Serialize(p); Console.WriteLine(json); var p1 = serializer.Deserialize<Project>(json); Console.WriteLine(p1.Input + "=>" + p1.Output); Console.WriteLine(ReferenceEquals(p,p1));
Project p = new Project() { Input = "stone", Output = "gold" }; DataContractJsonSerializer serializer = new DataContractJsonSerializer(p.GetType()); string jsonText; using (MemoryStream stream = new MemoryStream()) { serializer.WriteObject(stream, p); jsonText = Encoding.UTF8.GetString(stream.ToArray()); Console.WriteLine(jsonText); } using (MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(jsonText))) { DataContractJsonSerializer serializer1 = new DataContractJsonSerializer(typeof(Project)); Project p1 = (Project)serializer1.ReadObject(ms); Console.WriteLine(p1.Input + "=>" + p1.Output); }
[DataContract] class Project { [DataMember] public string Input { get; set; } [DataMember] public string Output { get; set; } }