Json簡略用法,
阿新 • • 發佈:2018-11-25
提醒一下:要把jobject值轉換為對應的類,用以下方式
JObject ja = (JObject)JsonConvert.DeserializeObject(xx);//xx為string格式的json資料 FaceDeteClass result1 = ja.ToObject<FaceDeteClass>();//FaceDeteClass為該資料對應的類,此處將該資料轉換為了對應類,更方便資料呼叫。當然如果你不嫌麻煩可以用Linq to Json呼叫。 當然你會覺得資料太大生成類很麻煩,此處推薦一個自動將結果生成對應類的網站:https://www.bejson.com/convert/json2csharp/,你只需要把結果貼上進去,然後就能生成類了,準確很高。
另,vs自帶也有該功能
JSON是什麼?
JSON是一種資料結構,主要用於各類資料傳輸,反正目前我只在http的時候遇到了。目測應該是跨平臺的資料傳輸吧,可以使用JSON格式的資料讀寫XML檔案,好像這個資料結構最開始是java使用的??這些都不重要,只要知道是幹嘛的以及怎麼幹就行了。
JSON.NET微軟爸爸的JSON操作類庫
1、在使用JSON.NET之前應該先引入JSON相應的EXE/DLL模組,比如Newtonsoft.Json檔案。
2、序列化與反序列化
2.2 JsonSerializer//序列化,Product是一個數據類,主要用於儲存各種屬性和引數。 Product product = new Product(); product.Name = "Apple"; product.ExpiryDate = new DateTime(2008, 12, 28); product.Price = 3.99M; product.Sizes = new string[] { "Small", "Medium", "Large" }; string output = JsonConvert.SerializeObject(product);//將product類轉化為字串 //{ // "Name": "Apple", // "ExpiryDate": "2008-12-28T00:00:00", // "Price": 3.99, // "Sizes": [ // "Small", // "Medium", // "Large" // ] //} //反序列化,將相關的字串結果轉化為對應的類 Product deserializedProduct = JsonConvert.DeserializeObject<Product>(output);//仔細體會尖括號
JsonSerializer可以直接通過流的方式來操作JSON資料。
將物件轉化為JSON格式的字串,然後儲存到本地:
Product product = new Product(); product.ExpiryDate = new DateTime(2008, 12, 28); JsonSerializer serializer = new JsonSerializer(); serializer.Converters.Add(new JavaScriptDateTimeConverter());//指定轉化日期的格式 serializer.NullValueHandling = NullValueHandling.Ignore;//忽略空值 using (StreamWriter sw = new StreamWriter(@"d:\json.txt")) using (JsonWriter writer = new JsonTextWriter(sw)) { serializer.Serialize(writer, product); // {"ExpiryDate":new Date(1230375600000),"Price":0} }
將本地檔案中的Json格式資料,轉化為JObject物件:
JsonSerializer serializer = new JsonSerializer();
serializer.Converters.Add(new JavaScriptDateTimeConverter());//指定轉化日期的格式
serializer.NullValueHandling = NullValueHandling.Ignore;//忽略空值
using (StreamReader sr = new StreamReader(@"d:\json.txt"))
using (JsonReader reader= new JsonTextReader(sr))
{
JObject jo =(JObject) serializer.Deserialize(reader);
// {
// "Name": null,
// "ExpiryDate": "2008-12-28T00:00:00",
// "Price": 0.0,
// "Sizes": null
//}
}
案例中的 serializer.NullValueHandling = NullValueHandling.Ignore 表示忽略空值,也就是為null值的屬性不轉化,需要注意Decimal的預設值不是null,而是0。
3.LINQ to JSON
Linq to Json可以非常快速的從JObject物件中查詢資料,以及建立JObject物件。
// create JObject
JObject o = JObject.Parse(@"{
'CPU': 'Intel',
'Drives': [
'DVD read/writer',
'500 gigabyte hard drive'
]
}");
// query JObject
string cpu = (string)o["CPU"];
// Intel
string firstDrive = (string)o["Drives"][0];
// DVD read/writer
IList<string> allDrives = o["Drives"].Select(t => (string)t).ToList();
// DVD read/writer
// 500 gigabyte hard drive
json和xml之間的轉換,請參考原文。。。。
轉載:https://www.cnblogs.com/HDK2016/p/7955179.html