c# 解析JSON的几种办法

 JSON简介

JSON(全称为JavaScript ObjectNotation) 是一种轻量级的数据交换格式。它是基于JavaScript语法标准的一个子集。JSON采用完全独立于语言的文本格式,可以很容易在各种网络、平台和程序之间传输。JSON的语法很简单,易于人阅读和编写,同时也易于机器解析和生成。

 

JSON与XML的比较

◆可读性

JSON和XML的可读性相比较而言,由于XML提供辅助的标签,更加适合人阅读和理解。

◆文件大小与传输

XML允许使用方便的标签,所以文件尺寸是要比JSON大的。而且JSON源于Javascript,所以天生的主战场是Javascript与网络,在这里,JSON有着XML无法赶超的优势。

 

JSON语法

1. JSON 语法是 JavaScript 对象表示法语法的子集。

数据在名称/值对中:名称是字符串,使用双引号表示。值可以是:数字(整数或浮点数),字符串(在双引号中),数组(在方括号中),对象(在花括号中),true/false/null。

数据由逗号分隔:

花括号保存对象:对象可以包含各种数据,包括数组。

方括号保存数组:数字可以包含对象。

例如:

 

 1 {  
 2    "students": [  
 3        {  
 4            "name": "coolszy",  
 5            "age": 24  
 6        },  
 7        {  
 8            "name": "kuka",  
 9            "age": 24  
10        }  
11     ]  
12 } 

 

2. 如果JSON中含有转义字符,则需要转义。

 

对比

.NET下几种常见的解析JSON方法
主要类命名空间限制内建LINQ支持
DataContractJsonSerializer System.Runtime.Serialization.Json 通用
JavaScriptSerializer System.Web.Script.Serialization 只能在Web环境使用
JsonArrayJsonObjectJsonValue System.Json 只能在Silverlight中使用
JsonConvertJArrayJObjectJValueJProperty Newtonsoft.Json 通用

准备数据

实体类:

    [DataContract]
    public class Person
    {
        [DataMember(Order = 0, IsRequired = true)]
        public string Name { get; set; }

        [DataMember(Order = 1)]
        public int Age { get; set; }

        [DataMember(Order = 2)]
        public bool Alive { get; set; }

        [DataMember(Order = 3)]
        public string[] FavoriteFilms { get; set; }

        [DataMember(Order = 4)]
        public Person Child { get; set; }
    }

定义:

Action<object> log = o => Console.WriteLine(o);
Func<int, int, int> add = (x, y) => x + y;

var p1 = new Person {
    Age = 12,
    Alive = true,
    Name = "lj",
    FavoriteFilms = new[] { "Up", "Avatar" }
};
var p2 = new Person() { Age = 28, Name = "cy", Child = p1 };

使用DataContractJsonSerializer

帮助类:

 // using System.Runtime.Serialization.Json;
    
    /// <summary>
    /// 解析JSON,仿Javascript风格
    /// </summary>
    public static class JSON
    {

        public static T parse<T>(string jsonString)
        {
            using (var ms = new MemoryStream(Encoding.UTF8.GetBytes(jsonString)))
            {
                return (T)new DataContractJsonSerializer(typeof(T)).ReadObject(ms);
            }
        }

        public static string stringify(object jsonObject)
        {
            using (var ms = new MemoryStream())
            {
                new DataContractJsonSerializer(jsonObject.GetType()).WriteObject(ms, jsonObject);
                return Encoding.UTF8.GetString(ms.ToArray());
            }
        }
    }

用法:

    // 序列化
    var jsonString = JSON.stringify(new[] { p1, p2 });
    log(jsonString == JSON.stringify(new List<Person>() { p1, p2 }));   //true
    log(jsonString);
    // 反序列化,泛型集合
    JSON.parse<List<Person>>(jsonString);
    // 数组转换            
    JSON.parse<Person[]>(jsonString);

输出:

[{"Name":"lj","Age":12,"Alive":true,"FavoriteFilms":["Up","Avatar"],"Child":null
},{"Name":"cy","Age":28,"Alive":false,"FavoriteFilms":null,"Child":{"Name":"lj",
"Age":12,"Alive":true,"FavoriteFilms":["Up","Avatar"],"Child":null}}]

使用JavaScriptSerializer

  // using System.Web.Script.Serialization;
    
    var jser    = new JavaScriptSerializer();
    var json    = jser.Serialize(new List<Person>() { p1, p2 });
    var persons = jser.Deserialize<List<Person>>(json);

使用Silverlight

  // using System.Json
    
    var css = "{ \"#header\" : {background:\"red\"}, layout : [5,4,1],color:\"cyan\" }";
    
    var style = JsonObject.Parse(css) as JsonObject;    
    
    (
    from s in style
    where s.Key == "color"
    select (string)s.Value
    ).First().ToString();    
    // "cyan"
    
    
    // 更多操作
    style["layout"][0] = 22;
    
    var hd = style["#header"];
    style["body>div+p"] = hd;
    style.Remove("#header");
    
    var bd = new JsonObject();
    bd["border"] = "1px solid cyan";
    style["body>div+p"]["#meta"] = bd;
    style.ToString();    
    // {"layout":[22,4,1],"color":"cyan","body>div+p":{"background":"red","#meta":{"border":"1px solid cyan"}}}

使用JSON.NET

  // using Newtonsoft.Json;
    
    var json = JsonConvert.SerializeObject(new[] { p1, p2 });
    var persons = JsonConvert.DeserializeObject<List<Person>>(json);
    var ja = JArray.Parse(jsonString);            
    log(ja);    //注意,格式化过的输出

输出:

[
  {
    "Name": "lj",
    "Age": 12,
    "Alive": true,
    "FavoriteFilms": [
      "Up",
      "Avatar"
    ],
    "Child": null
  },
  {
    "Name": "cy",
    "Age": 28,
    "Alive": false,
    "FavoriteFilms": null,
    "Child": {
      "Name": "lj",
      "Age": 12,
      "Alive": true,
      "FavoriteFilms": [
        "Up",
        "Avatar"
      ],
      "Child": null
    }
  }
]

LINQ:

    var ageCount = ja.Select(j => (int)j["Age"]).Aggregate(add);    
    var q = from j in ja
            where !j["Name"].Value<string>().Equals("lj")
            select (int)j["Age"];
    
    log(q.Aggregate(add) == ageCount);  //false

其他:

  // 与Linq to XML 相似的嵌套构造函数:
    var jo = new JObject(
                    new JProperty("age", persons.Select( p => p.Age)),
                    new JProperty("funny", true),
                    new JProperty("array", new JArray(new[] { 2, 4, 1 }))
                    );
    log(jo);
    
    // JObject 操作
    var css = "{ \"#header\" : {background:\"red\"}, layout : [5,4,1] }";
    var style = JObject.Parse(css);

    var bd = new JObject();
    bd["color"] = "1px solid cyan";

    style["border"] = bd;

    var hd = style["#header"];
    style["body>div+p"] = hd;

    hd.Parent.Remove();

    style["layout"][0] = 22;
    log(style);

输出:

    {
      "age": [
        12,
        28
      ],
      "funny": true,
      "array": [
        2,
        4,
        1
      ]
    }
    {
      "layout": [
        22,
        4,
        1
      ],
      "border": {
        "color": "1px solid cyan"
      },
      "body>div+p": {
        "background": "red"
      }
    }
posted @ 2014-11-30 21:35  tigermonkey  阅读(671)  评论(0)    收藏  举报