广告位联系
返回顶部
分享到

C#纯技术之Class写入Json介绍

C#教程 来源:互联网 作者:佚名 发布时间:2023-10-12 22:37:34 人浏览
摘要

C# Class写入Json 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 /// summary /// 写入json文件 /// /summary /// param name=obj/param /// param name=savePath/param public static void ConvertToJson(object obj, str

C# Class写入Json

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

/// <summary>

     /// 写入json文件

     /// </summary>

     /// <param name="obj"></param>

     /// <param name="savePath"></param>

     public static void ConvertToJson(object obj, string savePath)

     {

         string str = JsonConvert.SerializeObject(obj);

 

         //json格式化

         JsonSerializer jsonSerializer = new JsonSerializer();

         TextReader textReader = new StringReader(str);

         JsonTextReader jsonTextReader = new JsonTextReader(textReader);

         object _object = jsonSerializer.Deserialize(jsonTextReader);

         if (_object != null)

         {

             StringWriter stringWriter = new StringWriter();

             JsonTextWriter jsonWriter = new JsonTextWriter(stringWriter)

             {

                 Formatting = Formatting.Indented,

                 Indentation = 4,

                 IndentChar = ' '

             };

             jsonSerializer.Serialize(jsonWriter, _object);

             File.WriteAllText(savePath, stringWriter.ToString());

         }

     }

自定义的类不断迭代,然后通过json树模型写入json文件,这样得到的数据不仅轻量而且易读,是数据传输的优秀方式。

json和xml比较 笔者更喜欢xml

C# 操作JSON几种方式

通过两种在c#中常用的方式来实现对Json数据的序列化和反序列化,为了实现大多数的需求,我们采用稍微复杂一点的数据模型。

首先我们有以下json数据

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

{

  "name": "张三",

  "age": 20,

  "idCard": "123456789",

  "birthday": "2021-01-01 00:00:00",

  "hobbys": [

    {

      "sort": 1,

      "desc": "写字"

    },

    {

      "sort": 2,

      "desc": "游泳"

    }

  ]

}

然后我们根据json的结构创建一个实体类

1

2

3

4

5

6

7

8

9

10

11

12

13

private class Studet

{

    public string name { get; set; }

    public int age { get; set; }

    public string idCard { get; set; }

    public DateTime birthday { get; set; }

    public List<hobby> hobbys { get; set; }

}

private class hobby

{

    public int sort { get; set; }

    public string desc { get; set; }

}

第一种方式:JavaScriptSerializer

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

//需添加引用:System.Web.Extensions

//需导入命名空间:using System.Web.Script.Serialization;

  

  

//json.txt中的数据为上面的json数据

string json = File.ReadAllText("d:\\json.txt");

  

  

JavaScriptSerializer jss = new JavaScriptSerializer();

//反序列化成Studet对象

Studet student = jss.Deserialize<Studet>(json);

//然后就可以直接用操作对象的方法直接点出来就行

//输出:张三

Console.WriteLine(student.name);

  

  

//同样的,我们可以将上面的对象序列化成一个json数据

//序列化成json

string resultJson = jss.Serialize(student);

Console.WriteLine(resultJson);

第二种方式:JSON.NET

1

2

3

4

5

6

7

8

9

10

11

12

13

//需添加引用:Newtonsoft.Json

//需导入命名空间:using Newtonsoft.Json; using Newtonsoft.Json.Linq;

  

  

 //反序列化成对象

Studet student = JsonConvert.DeserializeObject<Studet>(json);

//输出:张三

Console.WriteLine(student.name);

  

  

//序列化成json

string resultJson = JsonConvert.SerializeObject(student);

Console.WriteLine(resultJson);

以上是我们通过json结构映射实体类的方式去实现的解析json数据,很多时候我们可能并不需要,或者并不想创建太多的类,这时候我们可以通过以下方式去实现解析

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

//使用JObject(JSON.NET)

//反序列化成JObject

JObject jobj = JObject.Parse(json);

//输出:张三

Console.WriteLine(jobj["name"].ToString());

//解析hobbys

 JArray jarr = JArray.Parse(jobj["hobbys"].ToString());

//迭代jarr即可

  

  

//同样的,假如我们有一个JObject对象

 JObject obj = new JObject();

 obj["name"] = "张三";

 obj["age"] = 20;

 //输出json数据,直接ToString()就可以

 Console.WriteLine(obj.ToString());

如果说你的Json结构是一个数组形式的话,即[{},{},{}],我们可以通过以下方式去解析

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

//第一种:DataTable

DataTable dt = JsonConvert.DeserializeObject<DataTable>(json);

//或者使用JavaScriptSerializer

dt =jss.Deserialize<DataTable>(json);

//解析DataTable即可

  

  

//第二种:JArray

JArray jarr = JArray.Parse(json);

//然后去迭代jarr即可

foreach (var j in jarr)

{

    Console.WriteLine(j["key"]);

}

  

  

//第三种,也就是我们上面提到了有实体类的情况下

List<Studet> list = JsonConvert.DeserializeObject<List<Studet>>(json);

以上基本可以解决我们的日常开发需求,个人推荐使用JSON.NET。


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 :
相关文章
  • C#中使用Spire.doc对word的操作方式介绍

    C#中使用Spire.doc对word的操作方式介绍
    使用Spire.doc对word的操作 在最近的工程中我们要处理一些word文档。通过在网上的大量搜索,我发现大多数软件功能不是不完整就是有重复。
  • C#纯技术之Class写入Json介绍

    C#纯技术之Class写入Json介绍
    C# Class写入Json 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 /// summary /// 写入json文件 /// /summary /// param name=obj/param /// param name=save
  • C#实体类转换的两种方式介绍
    C#实体类转换方式 将一个实体类的数据赋值到另一个实体类中(亦或者实现深拷贝)。 以下提供两种方式 一种是序列化 一种是泛型+反射
  • 在C#中构造自定义属性的详细介绍
    属性用于向程序添加元数据,例如编译器指令和其他信息,例如注释、描述、方法和类。 .Net Framework 允许创建可用于存储声明性信息并可在
  • 在C#中获取路径内的所有目录和子目录的教程
    要获取目录,C#提供了一个方法Directory.GetDirectories。Directory.GetDirectories方法返回与指定搜索模式在指定目录中匹配的子目录的名称(包括其路
  • C#实现窗体换肤的教程
    效果 代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
  • 【译】.NET 7 中的性能改进(二)
    原文 | Stephen Toub翻译 | 郑子铭堆栈替换 (On-Stack Replacement)堆栈替换 (OSR) 是 .NET 7 中最酷的 JIT 功能之一。但要真正了解 OSR,我们首先需要了解
  • C#将Excel转换为PDF的教程

    C#将Excel转换为PDF的教程
    转换场景 将Excel转换为PDF是一个很常用的功能 常见的转换场景有以下三种: 转换整个Excel文档到PDF 转换Excel文档的某一个工作表到PDF 转换
  • C#中的时间显示格式(12小时制VS24小时制)
    C#时间显示格式 一起看下: 24小时制 1 this.toolStripStatusLabel1.Text = 您好,欢迎来到XXXX控制系统! + 当前时间: + DateTime.Now.ToString(yyyy-MM-dd HH
  • C#实现图片轮播功能的代码
    实践过程 效果 代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 5
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计