首页 > 代码库 > 操作Json

操作Json

C#可以像Javascript一样操作Json

阅读目录

 

  • Json的简介
  • Json的优点
  • 传统操作Json
  • 简易操作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吧。

操作Json