首页 > Windows开发 > 详细

C#中两种方式转换Json的方法

时间:2020-08-06 01:22:15      阅读:117      评论:0      收藏:0      [点我收藏+]

方法一:拼接字符串

优点:自定义,灵活度高
缺点:编码容易出差错,还要处理末尾的元素

  string str = "{";
  for (int i = 0; i < list_head.Count; i++)
  {
       str += "\""+list_head[i]+"\":[";
       var value=list.Where(x => x.TypeName == list_head[i]).ToList();
          for (int j = 0; j < value.Count; j++)
                {
                    if (j== value.Count-1)
                    {
    str += "{\"ID\":\"" + value[j].ID + "\",\"Number\":\"" + value[j].Number + "\",\"TypeName\":\"" + value[j].TypeName + "\"}";
                    }
                    else
                    {
     str += "{\"ID\":\"" + value[j].ID + "\",\"Number\":\"" + value[j].Number + "\",\"TypeName\":\"" + value[j].TypeName + "\"},";
                    }
                }
                if (i== list_head.Count-1)
                {
                    str += "]";
                }
                else
                {
                    str += "],";
                }
            }
            str += "}";

方法二:使用第三方库(Newtonsoft)

优点:直接调用第三方封装好的方法,使用方便简洁
缺点:有版本的区别(其实也不算缺点),没有方法一灵活,其他都比较好

//模型类,定义Json结构
public class BaseModel
{
public List<ModelData> list_student { get; set; } = new List<ModelData>();
public List<ModelData> list_teacher { get; set; } = new List<ModelData>();
public List<ModelData> list_headteacher { get; set; } = new List<ModelData>();
public List<ModelData> list_gradedirector { get; set; } = new List<ModelData>();
public List<ModelData> list_deanr { get; set; } = new List<ModelData>();
}
//实例化,存储数据
BaseModel model = new BaseModel();
model.list_student = list.Where(x => x.TypeName == "学生").ToList();
model.list_teacher = list.Where(x => x.TypeName == "老师").ToList();
model.list_headteacher = list.Where(x => x.TypeName == "班主任").ToList();
model.list_gradedirector = list.Where(x => x.TypeName == "年级主任").ToList();
model.list_deanr = list.Where(x => x.TypeName == "院长").ToList();
string json2=JsonConvert.SerializeObject(model);

其他代码

//模型类
   public class ModelData
    {
        public ModelData(int iD, int number, string typeName)
        {
            ID = iD;
            Number = number;
            TypeName = typeName;
        }

        public int ID { get; set; }
        public int Number { get; set; }
        public string TypeName { get; set; }
    }
//测试数据
 class Program
    {
        static void Main(string[] args)
        {
            List<ModelData> list = new List<ModelData>(100);

            for (int i = 1; i <=100; i++)
            {
                if (i<50)
                {
                    list.Add(new ModelData(i, 10, "学生"));
                }
                else if (i>=50&&i<75)
                {
                    list.Add(new ModelData(i, 20, "老师"));
                }
                else if (i >= 75 && i <85)
                {
                    list.Add(new ModelData(i, 30, "班主任"));
                }
                else if (i >= 85 && i < 95)
                {
                    list.Add(new ModelData(i, 40, "年级主任"));
                }
                else
                {
                    list.Add(new ModelData(i, 40, "院长"));
                }
            }
            BaseModel model = new BaseModel();
            model.list_student = list.Where(x => x.TypeName == "学生").ToList();
            model.list_teacher = list.Where(x => x.TypeName == "老师").ToList();
            model.list_headteacher = list.Where(x => x.TypeName == "班主任").ToList();
            model.list_gradedirector = list.Where(x => x.TypeName == "年级主任").ToList();
            model.list_deanr = list.Where(x => x.TypeName == "院长").ToList();

            List<string> list_head = new List<string>() { "学生", "老师", "班主任", "年级主任","院长" };
            string str = "{";
            for (int i = 0; i < list_head.Count; i++)
            {
               str += "\""+list_head[i]+"\":[";
               var value=list.Where(x => x.TypeName == list_head[i]).ToList();
                for (int j = 0; j < value.Count; j++)
                {
                    if (j== value.Count-1)
                    {
                        str += "{\"ID\":\"" + value[j].ID + "\",\"Number\":\"" + value[j].Number + "\",\"TypeName\":\"" + value[j].TypeName + "\"}";
                    }
                    else
                    {
                        str += "{\"ID\":\"" + value[j].ID + "\",\"Number\":\"" + value[j].Number + "\",\"TypeName\":\"" + value[j].TypeName + "\"},";
                    }
                }
                if (i== list_head.Count-1)
                {
                    str += "]";
                }
                else
                {
                    str += "],";
                }
            }
            str += "}";
            Console.WriteLine(str);
            Console.WriteLine("-------------------------------------------------");
            string json2=JsonConvert.SerializeObject(model);
            Console.WriteLine(json2);

            Console.ReadKey();
        }

总结

方法二确实好,也有很多人使用,方法一也有自己的优点,如果格式唯一,改动小,可以直接使用方法二直接搞笑,如果格式经常需要改动,或者数据比较小的时候,用方法一,这个方便修改!主要是今天我用方法一做的程序,被老大说了,这种写法不好,直接否掉了,让我用第二种方法,在这记录一下!

C#中两种方式转换Json的方法

原文:https://www.cnblogs.com/2828sea/p/13443605.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!