• c#解析json字符串处理


    转载自:https://www.cnblogs.com/wfy680/p/11966623.html

    为了防止帖子丢失所以我又复制了一下

    需求:

    假设有如下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/ )。

    // 20190105更新,之前这个网站是直接一个大按钮下载dll的,好像现在变复杂了2333,也可以去里面的github-release链接里,下载最新压缩包json-xxx.zip,解压找到自己对应的.net版本的Newtonsoft.Json.dll 

    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<T>。关于泛型列表的有关内容在这篇文章里就不再赘述了,大家可以直接把它当成数组使用。遍历数组的方法在此依然适用,例如代码中的:

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

    看到有的人问如何把对象转换成json,我这边就补充一下吧,其实同样也是用这个库自带的方法,代码如下:

    (直接加在Console.ReadKey()上面就可以运行了)

    Employees e1 = new Employees();
    e1.firstName = "Ma";
    e1.lastName = "Yun";

    Manager m1 = new Manager();
    m1.salary = "6666";
    m1.age = "30";

    RootObject robj = new RootObject();
    robj.employees = new List<Employees>();
    robj.manager = new List<Manager>();

    robj.companyID = "ALI BABA";
    robj.employees.Add(e1);
    robj.manager.Add(m1);

    string str = JsonConvert.SerializeObject(robj);
    Console.WriteLine(str);
    就是调用库里面的SerializeObject方法,传入赋值好的对象就好了

    最后程序输出json字符串:

    {"companyID":"ALI BABA","employees":[{"firstName":"Ma","lastName":"Yun"}],"manager":[{"salary":"6666","age":"30"}]}

  • 相关阅读:
    十四、内存泄露和强软弱虚引用
    十五、对象的内存布局
    Android Service全解(三)之 Foreground Service(转)
    android中不同activity的传参调用和返回
    Android Service全解(一)之 startService(转)
    Android Service全解(二)之 bindService(转)
    android单点、多点触控之MotionEvent
    关于创建进程函数CreateProcess()字符串参数的说明
    sql中连接两个不同的数据库(A在同一个服务器,B不在一个服务器)
    asp.net小数点四舍五入的方法
  • 原文地址:https://www.cnblogs.com/zhouchen0408/p/12683834.html
Copyright © 2020-2023  润新知