C#纯技术之Class写入Json cctv5体育节目表

   2023-02-07 学习力0
核心提示:目录C# Class写入JsonC# 操作JSON几种方式第一种方式:JavaScriptSerializer第二种方式:JSON.NET总结C# Class写入Json /// summary/// 写入json文件/// /summary/// param name="obj"/param/// param name="savePath"/parampublic static void ConvertToJson

C# Class写入Json

   /// <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#纯技术之Class写入Json

C# 操作JSON几种方式

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

首先我们有以下json数据

{
  "name": "张三",
  "age": 20,
  "idCard": "123456789",
  "birthday": "2021-01-01 00:00:00",
  "hobbys": [
    {
      "sort": 1,
      "desc": "写字"
    },
    {
      "sort": 2,
      "desc": "游泳"
    }
  ]
}

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

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

//需添加引用: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

//需添加引用: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数据,很多时候我们可能并不需要,或者并不想创建太多的类,这时候我们可以通过以下方式去实现解析

//使用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结构是一个数组形式的话,即[{},{},{}],我们可以通过以下方式去解析

//第一种: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。

总结

这些仅为个人经验,希望能给大家一个参考,也希望大家多多支持。

原文地址:https://blog.csdn.net/qq_35619526/article/details/99703352
 
标签: C# Class 写入 Json
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

点击排行