C#處理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); } </pre> (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);
</pre> (3)使用JObject讀寫字符串:
JObject jo = JObject.Parse(jsonText); string[] values = jo.Properties().Select(item => item.Value.ToString()).ToArray();
</pre> (4)使用JsonSerializer讀寫對象(基于JsonWriter與JsonReader):
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);
</pre> 上面的代碼都是基于下面這個Project類定義:
class Project { public string Input { get; set; } public string Output { get; set; } }此外,如果上面的JsonTextReader等類編譯不過的話,說明是我們自己修改過的類,換成你們自己的相關類就可以了,不影響使用。
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)); </pre> 注意:如果使用的是VS2010,則要求當前的工程的Target Framework要改成.Net Framework 4,不能使用Client Profile。當然這個System.Web.Extensions.dll主要是Web使用的,直接在Console工程中用感覺有點浪費資源。
此外,從最后一句也可以看到,序列化與反序列化是深拷貝的一種典型的實現方式。
4. 契約方式:使用System.Runtime.Serialization.dll提供的DataContractJsonSerializer或者 JsonReaderWriterFactory實現。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); }
</pre>
這里要注意,這里的Project類和成員要加相關的Attribute:[DataContract] class Project { [DataMember] public string Input { get; set; } [DataMember] public string Output { get; set; } }</pre>
實用參考:
JSON驗證工具:http://jsonlint.com/
JSON簡明教程:http://www.w3school.com.cn/json/
Newtonsoft.Json類庫下載:http://json.codeplex.com/