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. 通用方式【】:
(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讀寫對象(基于JsonWriter與JsonReader):
數組型資料
嵌套格式
自定義類Project
Project p = new Project() { Input = "stone", Output = "gold" };
JsonSerializer serializer = new JsonSerializer();
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; }
此外,如果上面的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));
注意:如果使用的是VS2010,則要求目前的工程的Target Framework要改成.Net Framework 4,不能使用Client Profile。當然這個System.Web.Extensions.dll主要是Web使用的,直接在Console工程中用感覺有點浪費資源。
此外,從最後一句也可以看到,序列化與反序列化是深拷貝的一種典型的實作方式。
4. 契約方式:使用System.Runtime.Serialization.dll提供的DataContractJsonSerializer或者 JsonReaderWriterFactory實作。
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);
這裡要注意,這裡的Project類和成員要加相關的Attribute:
[DataContract]
[DataMember]
實用參考:
JSON驗證工具:http://jsonlint.com/
JSON簡明教程:http://www.w3school.com.cn/json/
Newtonsoft.Json類庫下載下傳:http://json.codeplex.com/
歡迎關注方倍工作室微信,了解我們及行業的最新動态
![](https://img.laitimes.com/img/_0nNw4CM6IyYiwiM6ICdiwiInBnauUTMiVWOlRmYmZWOmFTYyITN4QGNjRzNjZjMkJjY5YGOfdWbp9CXt92Yu4GZjlGbh5SZslmZxl3Lc9CX6MHc0RHaiojIsJye.jpg)