C#/WPF JSON序列化和反序列化

什么是json

json是存储和交换文本信息的方法,类似xml。但是json比xml更小,更快,更易于解析。并且json采用完全独立于语言的文本格式(即不依赖于各种编程语言),这些特性使json成为理想的数据交换语言。json序列化是指将对象转换成json字符串,json反序列化是指将json字符串还原成对象。

json数据结构

json简单来说就是javascript中的对象和数组,通过这两种数据结构就可以表示各种复杂的结构。
对象:对象在json中表示为大括号"{}"括起来的内容,数据结构为{key:value,key:value,...}的键值对的结构。在面向对象中,key为对象的属性,vlaue为对应属性的值。
数组:数组在json中表示为中括号"[]"括起来的内容,数据结构为["java","javascript","vb",...],取值方式和所以语言一样,使用索引获取,字段的值可以是数字,字符串,数组,对象。

C#使用json序列化有几种方式

  • 使用System.Text.Json(微软自带)
  • 使用Newtonsoft.Json(引用Newtonsoft.Json.dll)
  • System.Runtime.Serialization.Json(以数据流为中介)
  • Nancy(包)
使用System.Text.Json
复制代码
      #region using System.Text.Json
      private static string ObjectToStringOne(Object obj)
      {
          string str = System.Text.Json.JsonSerializer.Serialize(obj);
          return str;
      }
      private static T StringToObjectOne<T>(string str)
      {
          T obj = System.Text.Json.JsonSerializer.Deserialize<T>(str);
          return obj;
      }
      #endregion
使用Newtonsoft.Json
复制代码
      #region using NewTonsoft.Json
      private static string ObjectToStringTwo(Object obj)
      {
          string str = Newtonsoft.Json.JsonConvert.SerializeObject(obj);
          return str;
      }

      private static T StringToObjectTwo<T>(string str)
      {
          T obj = Newtonsoft.Json.JsonConvert.DeserializeObject<T>(str);
          return obj;
      }
      #endregion
获取序列化字符串中某个字段
cs 复制代码
using Newtonsoft.Json.Linq;
jsonStr={"resCode":0,"resMeg":"空闲","data":[{"parkName": "A停车场","freeSpaceNum":72}]}
JObject obj = JObject.Parse(jsonStr);
string resMeg= obj["resMag"].ToString(); // 获取resMeg字段的值
string freSpaceNum = obj["data"][0]["freSpaceNum"].ToString();

参考:

C#中 Json序列化与反序列的几种方法_c# json序列化-CSDN博客

相关推荐
じòぴé南冸じょうげん2 天前
小程序的project.private.config.json是无依赖文件,那可以删除吗?
前端·小程序·json
luckys.one2 天前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
小菜全2 天前
基于若依框架Vue+TS导出PDF文件的方法
javascript·vue.js·前端框架·json
CodeCraft Studio3 天前
Excel处理控件Aspose.Cells教程:使用 Python 将 Pandas DataFrame 转换为 Excel
python·json·excel·pandas·csv·aspose·dataframe
敬业小码哥3 天前
记一次:mysql的json及json数组使用组合使用
数据库·mysql·json
一键三联啊3 天前
BSON 和 JSON 的区别
json
一个很老的小萌新5 天前
json 解析 [{“id“:1,“name“:“apple“},{“id“:2,“name“:“banana“}]
java·前端·json
微笑伴你而行5 天前
目标检测如何将同时有方形框和旋转框的json/xml标注转为txt格式
xml·目标检测·json
cdcdhj6 天前
数据库存储大量的json文件怎么样高效的读取和分页,利用文件缓存办法不占用内存
缓存·node.js·json