1. 程式人生 > >Json簡略用法,

Json簡略用法,

提醒一下:要把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、序列化與反序列化

//序列化,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);//仔細體會尖括號
2.2 JsonSerializer

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