zoukankan      html  css  js  c++  java
  • c#解析json字符串处理(最清晰易懂的方法)

    注:博客迁移到csdn,本文最新地址:https://blog.csdn.net/sajiazaici/article/details/77647625

    以下为原文

    本文是全网第二简单的方法,因为我女票也发了一篇博客说是全网最简单的方法,我不能和她争。。。

    PS:网络上还有各种各样的方法大家可以自行探究,不过我敢说肯定没有本文讲的清晰。。几句话就解决的事绕来绕去的说。。

    (完整代码在文末,引用库文件后可直接运行)

    需求:

    假设有如下json字符串:

    {
        "companyID": "15",
    
        "employees": [
            {
                "firstName": "Bill",
                "lastName": "Gates"
            },
            {
                "firstName": "George",
                "lastName": "Bush"
            }
        ],
    
        "manager": [
            {
                "salary": "6000",
                "age": "23"
            },
            {
                "salary": "8000",
                "age": "26"
            }
        ]
    
    }

    请利用C#处理这个字符串,在控制台显示出公司的ID,第一位员工的姓,和所有管理者的工资。

    解决步骤:

    (为了更清晰的说明,本例在控制台中测试,本人编程环境VS2015)

    1、下载开源的类库Newtonsoft.Json(下载地址 http://json.codeplex.com/ )。

    2、在VS中新建项目——控制台应用程序。

    3、引用类库:在VS中点击:项目——引用——浏览——找到你刚才下载的Newtonsoft.Json.dll——确定。

    4、在主程序Program.cs的开头添加 using Newtonsoft.Json;  这一语句。

    5、把要处理的json字符串复制到 http://json2csharp.chahuo.com/  得到C#类,如图所示:

    把这部分内容复制,粘贴到class Program类的下方。

    6、为了方便演示,把我给的json字符串赋值给一个变量。但是json中有很多的引号,赋值给一个string变量还要加上很多的反斜杠。这里再给大家一个在线工具:http://tool.chinaz.com/tools/jsonescape.aspx

    将我刚才给的东西复制进去点击“压缩并转义”,得到的值可以直接赋值给一个string变量,如图:

    PS:如果能从别的地方比如webAPI得到json字符串那更好,直接赋值给一个string变量后进行下面的操作,省去了转义这一步。

    string jsonText = " {"companyID":"15","employees":[{"firstName":"Bill","lastName":"Gates"},{"firstName":"George","lastName":"Bush"}],"manager":[{"salary":"6000","age":"23"},{"salary":"8000","age":"26"}]}  ";
    

    7、反序列化json字符串得到对象。

    RootObject rb = JsonConvert.DeserializeObject<RootObject>(jsonText);

    8、处理对象,如输出公司ID:

    Console.WriteLine(rb.companyID);

    完整代码如下(引用NewtonSoft.Json.dll后可直接运行):

    using Newtonsoft.Json;
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace ConsoleJsonTest
    {
        class Program
        {
            static void Main(string[] args)
            {
    
                string jsonText = " {"companyID":"15","employees":[{"firstName":"Bill","lastName":"Gates"},{"firstName":"George","lastName":"Bush"}],"manager":[{"salary":"6000","age":"23"},{"salary":"8000","age":"26"}]} ";
                Console.WriteLine(jsonText);
    
                RootObject rb = JsonConvert.DeserializeObject<RootObject>(jsonText);
    
                Console.WriteLine(rb.companyID);
    
                Console.WriteLine(rb.employees[0].firstName);
    
                foreach (Manager ep in rb.manager)
                {
                    Console.WriteLine(ep.age);
                }
    
                Console.ReadKey();
            }
        }
    
        public class Employees
        {
            public string firstName { get; set; }
            public string lastName { get; set; }
        }
    
        public class Manager
        {
            public string salary { get; set; }
            public string age { get; set; }
        }
    
        public class RootObject
        {
            public string companyID { get; set; }
            public List<Employees> employees { get; set; }
            public List<Manager> manager { get; set; }
        }
    }
    

    输出结果:

    说明:对于json字符串中的数组,如本例中的employees或者manager,用这篇文章里的在线工具会自动生成列表List<>。关于列表的有关内容在这篇文章里就不再赘述了,大家可以直接把它当成数组使用。遍历数组的方法在此依然适用,例如代码中的:

    foreach (Manager ep in rb.manager)
     {
                Console.WriteLine(ep.age);
     }

    广告:女票的全网最简单方法在这:http://blog.csdn.net/weixin_39874268/article/details/77302255

    虽然我觉得她讲的不是很清楚但是我不能这么说...她依然是全网最简单的方法!嗯!

  • 相关阅读:
    .NET基础之:i++和i=i+1和++i的区别
    几个缩写
    下一步工作的一些思考和问题
    显著提高应变的定位精度和颗粒大小
    两个使用的Ajax Demo
    SQL Service查询分析
    自学面向对象
    支持定位当前页,自定义排序的分页SQL(拒绝动态SQL)
    WCF学习经验分享,如何更好地学习WCF?
    Custom DataContractSerializerOperationBehavior
  • 原文地址:https://www.cnblogs.com/dhx96/p/7381124.html
Copyright © 2011-2022 走看看