• 操作Json


    C#可以像Javascript一样操作Json

    阅读目录

     

     

     

    Json的简介

     

     

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C、C++、C#、Java、JavaScript、Perl、Python等)。这些特性使JSON成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成(一般用于提升网络传输速率)。

                                                                        来自百度百科的介绍

     

     

     

    Json的优点

     

     

    • 数据格式比较简单,易于读写,格式都是压缩的,占用带宽小
    • 易于解析,客户端JavaScript可以简单的通过eval()进行JSON数据的读取;
    • 支持多种语言,包括ActionScript, C, C#, ColdFusion, Java, JavaScript, Perl, PHP, Python, Ruby等服务器端语言,便于服务器端的解析;
    • 在PHP世界,已经有PHP-JSON和JSON-PHP出现了,偏于PHP序列化后的程序直接调用,PHP服务器端的对象、数组等能直接生成JSON格式,便于客户端的访问提取;
    • 因为JSON格式能直接为服务器端代码使用,大大简化了服务器端和客户端的代码开发量,且完成任务不变,并且易于维护。

     

     

     

    传统操作Json

     

     

    很多.NET开发程序员或多或少都会遇到操作Json字符串的情况,一般来说,我们都是先定义一个和Json格式相匹配的类,然后将json字符串反序列化成对象,这样便于我们编程使用,由于.NET是强类型语言,Json又是多变的,非常灵活的,导致服务器端定义的json序列化类越来越多,操作也及其不便。特别是对多层嵌套的json更是头疼。此次不再过多声明,.NET程序员用过都明白。

     

     

     

    简易操作Json

     

     

    DynamicJson是专门为.NET程序员开发的Json操作库,其源码非常简单,仅仅只有400行代码,一个对应的class类,目前只支持.NET 4.0以上的.NET Framework。

     

     

    如何在项目中使用DynamicJson

     

    • 直接通过Nuget安装

     

    1
    PM > Install-Package DynamicJson

     

    • 下载DynamicJson.dll,然后在项目中添加引用,下载地址如下:

     

    1
    http://dynamicjson.codeplex.com/

     

     

    读取、获取

     

     

    1
    2
    3
    4
    5
    6
    7
    // 将Json字符串解析成DynamicJson对象
    var json = DynamicJson.Parse(@"{""foo"":""json"", ""bar"":100, ""nest"":{ ""foobar"":true } }");
     
    var r1 = json.foo; // "json" - string类型
    var r2 = json.bar; // 100 - double类型
    var r3 = json.nest.foobar; // true - bool类型
    var r4 = json["nest"]["foobar"]; // 还可以和javascript一样通过索引器获取

     

      

     

    判断,新增,更新,删除,替换,还可以输出新的Json字符串

     

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    // 将Json字符串解析成DynamicJson对象
                var json = DynamicJson.Parse(@"{""foo"":""json"", ""bar"":100, ""nest"":{ ""foobar"":true } }");
     
                // 判断json字符串中是否包含指定键
                var b1_1 = json.IsDefined("foo"); // true
                var b2_1 = json.IsDefined("foooo"); // false
                // 上面的判断还可以更简单,直接通过json.键()就可以判断
                var b1_2 = json.foo(); // true
                var b2_2 = json.foooo(); // false;
     
     
                // 新增操作
                json.Arr = new string[] { "NOR""XOR" }; // 新增一个js数组
                json.Obj1 = new { }; // 新增一个js对象
                json.Obj2 = new { foo = "abc", bar = 100 }; // 初始化一个匿名对象并添加到json字符串中
     
                // 删除操作
                json.Delete("foo");
                json.Arr.Delete(0);
                // 还可以更简单去删除,直接通过json(键); 即可删除。
                json("bar");
                json.Arr(1);
     
                // 替换操作
                json.Obj1 = 5000;
     
                // 创建一个新的JsonObject
                dynamic newjson = new DynamicJson();
                newjson.str = "aaa";
                newjson.obj = new { foo = "bar" };
     
                // 直接序列化输出json字符串
                var jsonstring = newjson.ToString(); // {"str":"aaa","obj":{"foo":"bar"}}

     

      

     

    遍历

     

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    // 直接遍历json数组
               var arrayJson = DynamicJson.Parse(@"[1,10,200,300]");
               foreach (int item in arrayJson)
               {
                   Console.WriteLine(item); // 1, 10, 200, 300
               }
     
               // 直接遍历json对象
               var objectJson = DynamicJson.Parse(@"{""foo"":""json"",""bar"":100}");
               foreach (KeyValuePair<string, dynamic> item in objectJson)
               {
                   Console.WriteLine(item.Key + ":" + item.Value); // foo:json, bar:100
               }

     

      

     

    转换和反序列化

     

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    public class FooBar
            {
                public string foo { getset; }
                public int bar { getset; }
            }
     
    var arrayJson = DynamicJson.Parse(@"[1,10,200,300]");
                var objectJson = DynamicJson.Parse(@"{""foo"":""json"",""bar"":100}");
     
                // 将json数组转成C#数组
                // 方法一:
                var array1 = arrayJson.Deserialize<int[]>();
                // 方法二
                var array2 = (int[])arrayJson;
                // 方法三,这种最简单,直接声明接收即可,推荐使用
                int[] array3 = arrayJson;
     
                // 将json字符串映射成C#对象
                // 方法一:
                var foobar1 = objectJson.Deserialize<FooBar>();
                // 方法二:
     
                var foobar2 = (FooBar)objectJson;
                // 方法三,这种最简单,直接声明接收即可,推荐使用
                FooBar foobar3 = objectJson;
     
                // 还可以通过Linq进行操作
                var objectJsonList = DynamicJson.Parse(@"[{""bar"":50},{""bar"":100}]");
                var barSum = ((FooBar[])objectJsonList).Select(fb => fb.bar).Sum(); // 150
                var dynamicWithLinq = ((dynamic[])objectJsonList).Select(d => d.bar);

     

      

     

     

    序列化成json字符串

     

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    // 声明一个匿名对象
               var obj = new
               {
                   Name = "Foo",
                   Age = 30,
                   Address = new
                   {
                       Country = "Japan",
                       City = "Tokyo"
                   },
                   Like = new[] { "Microsoft""Xbox" }
               };
               // 序列化
               // {"Name":"Foo","Age":30,"Address":{"Country":"Japan","City":"Tokyo"},"Like":["Microsoft","Xbox"]}
               var jsonStringFromObj = DynamicJson.Serialize(obj);
     
               // 还支持直接序列化数组,集合
               // [{"foo":"fooooo!","bar":1000},{"foo":"orz","bar":10}]
               var foobar = new FooBar[] {
                   new FooBar { foo = "fooooo!", bar = 1000 },
                   new FooBar { foo = "orz", bar = 10 }
               };
               // 序列化
               var jsonFoobar = DynamicJson.Serialize(foobar);

     

      

     

    生成xml字符串

     

     

    1
    2
    var obj = DynamicJson.Parse(@"{""tes"":10,""nest"":{""a"":0}");
    var xmlStr=obj.xml;

     

      

     

     

    其他(冲突问题,编译不通过问题)

     

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    var nestJson = DynamicJson.Parse(@"{""tes"":10,""nest"":{""a"":0}");
     
                nestJson.nest(); // 判断是否存在nest属性
                nestJson.nest("a"); // 删除nest属性中的a属性
     
                // 处理json中的键和C#的类型冲突导致编译失败,或语法提示错误,只需要在前面加@前缀即可
                var json = DynamicJson.Parse(@"{""int"":10,""event"":null}");
                var r1 = json.@int// 10.0
                var r2 = json.@event// null

     

      

     

     

    例子一:TwitterAPI

     

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    static void Main()
    {
        var publicTL = new WebClient().DownloadString(@"http://twitter.com/statuses/public_timeline.json");
        var statuses = DynamicJson.Parse(publicTL);
        foreach (var status in statuses)
        {
            Console.WriteLine(status.user.screen_name);
            Console.WriteLine(status.text);
        }
    }

     

      

     

    例子二:TwitterAPI2

     

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    static void Main(string[] args)
    {
        var wc = new WebClient();
        var statuses = Enumerable.Range(1, 5)
            .Select(i =>
                wc.DownloadString("http://twitter.com/statuses/user_timeline/neuecc.json?page=" + i))
            .SelectMany(s => (dynamic[])DynamicJson.Parse(s))
            .OrderBy(j => j.id);
     
        foreach (var status in statuses)
        {
            Console.WriteLine(status.text);
        }
    }

     

      

     

     

    看到这里,是不是觉得很爽,赶快让你的项目集成DynamicJson吧。

  • 相关阅读:
    javac 小记
    安全专家的工具箱
    MyBatis 缓存机制(十三)
    SpringMVC 环境搭建
    MyBatis 模糊查询的 4 种实现方式
    MyBatis 项目开发中是基于 XML 还是注解?
    MyBatis 动态 SQL 语句中出现 '<' 的问题
    数据库设计的三大范式
    mybatis 同时使用 XML 和注解
    数据库事务
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/5863153.html
Copyright © 2020-2023  润新知