C# Newtonsoft.Json解析json字符串处理(最清晰易懂的方法)

2021-02-06 11:17

阅读:573

标签:sele   space   复制   地址   json解析   关于   idt   工资   利用   

需求:

假设有如下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.DeserializeObjectRootObject>(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(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 { get; set; }  
        public List manager { get; set; }  
    }  
}  

 

输出结果:

技术图片

 

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

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

 

C# Newtonsoft.Json解析json字符串处理(最清晰易懂的方法)

标签:sele   space   复制   地址   json解析   关于   idt   工资   利用   

原文地址:https://www.cnblogs.com/zouhao/p/11420072.html


评论


亲,登录后才可以留言!