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。

数据由逗号分隔:

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

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

例如:

[html] view plaincopyprint?

  1. "students": [ 
  2. "name": "coolszy", 
  3. "age": 24 
  4. }, 
  5. "name": "kuka", 
  6. "age": 24 
  7. }
{
"students": [
{
"name": "coolszy",
"age": 24
},
{
"name": "kuka",
"age": 24
}
]
}

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

C#操作JSON

JSON文件读入到内存中就是字符串,.NET操作JSON就是生成与解析JSON字符串。操作JSON通常有以下几种方式:

1. 原始方式

自己按照JSON的语法格式,写代码直接操作JSON字符串。如非必要,应该很少人会走这条路,从头再来的。

2. 通用方式

这种方式是使用开源的类库Newtonsoft.Json(下载地址http://json.codeplex.com/)。下载后加入工程就能用。通常可以使用JObject, JsonReader, JsonWriter处理。这种方式最通用,也最灵活,可以随时修改不爽的地方。

(1)使用JsonReader读Json字符串:

[csharp] view plaincopyprint?

  1. string jsonText =@"{""input"" : ""value"",""output"" : ""result""}"; 
  2. JsonReader reader = new JsonTextReader(newStringReader(jsonText)); 
  3. while (reader.Read()) 
  4. Console.WriteLine(reader.TokenType + "\t\t" + reader.ValueType+ "\t\t" + reader.Value); 
  5. }
string jsonText =@"{""input"" : ""value"",""output"" : ""result""}";
JsonReader reader = new JsonTextReader(newStringReader(jsonText));
while (reader.Read())
{
Console.WriteLine(reader.TokenType + "\t\t" + reader.ValueType+ "\t\t" + reader.Value);
}

(2)使用JsonWriter写字符串:

[csharp] view plaincopyprint?

  1. StringWriter sw = new StringWriter(); 
  2. JsonWriter writer = new JsonTextWriter(sw); 
  3. writer.WriteStartObject(); 
  4. writer.WritePropertyName("input"); 
  5. writer.WriteValue("value"); 
  6. writer.WritePropertyName("output"); 
  7. writer.WriteValue("result"); 
  8. writer.WriteEndObject(); 
  9. writer.Flush(); 
  10. string jsonText =sw.GetStringBuilder().ToString(); 
  11. Console.WriteLine(jsonText);
StringWriter sw = new StringWriter();
JsonWriter writer = new JsonTextWriter(sw); writer.WriteStartObject();
writer.WritePropertyName("input");
writer.WriteValue("value");
writer.WritePropertyName("output");
writer.WriteValue("result");
writer.WriteEndObject();
writer.Flush(); string jsonText =sw.GetStringBuilder().ToString();
Console.WriteLine(jsonText);

(3)使用JObject读写字符串:

[csharp] view plaincopyprint?

  1. JObject jo = JObject.Parse(jsonText); 
  2. string[] values =jo.Properties().Select(item => item.Value.ToString()).ToArray();
JObject jo = JObject.Parse(jsonText);
string[] values =jo.Properties().Select(item => item.Value.ToString()).ToArray();

(4)使用JsonSerializer读写对象(基于JsonWriter与JsonReader):

数组型数据

[csharp] view plaincopyprint?

  1. string jsonArrayText1 ="[{'a':'a1','b':'b1'},{'a':'a2','b':'b2'}]"; 
  2. JArray ja =(JArray)JsonConvert.DeserializeObject(jsonArrayText1); 
  3. string ja1a =ja[1]["a"].ToString(); 
  4. //或者

  5. JObject o = (JObject)ja[1]; 
  6. string oa = o["a"].ToString();
string jsonArrayText1 ="[{'a':'a1','b':'b1'},{'a':'a2','b':'b2'}]";
JArray ja =(JArray)JsonConvert.DeserializeObject(jsonArrayText1);
string ja1a =ja[1]["a"].ToString();
//或者
JObject o = (JObject)ja[1];
string oa = o["a"].ToString();

嵌套格式

[csharp] view plaincopyprint?

  1. string jsonText ="{\"beijing\":{\"zone\":\"海淀\",\"zone_en\":\"haidian\"}}"; 
  2. JObject jo =(JObject)JsonConvert.DeserializeObject(jsonText); 
  3. string zone =jo["beijing"]["zone"].ToString(); 
  4. string zone_en =jo["beijing"]["zone_en"].ToString();
string jsonText ="{\"beijing\":{\"zone\":\"海淀\",\"zone_en\":\"haidian\"}}";
JObject jo =(JObject)JsonConvert.DeserializeObject(jsonText);
string zone =jo["beijing"]["zone"].ToString();
string zone_en =jo["beijing"]["zone_en"].ToString();

自定义类Project

[csharp] view plaincopyprint?

  1. Project p = new Project() { Input ="stone", Output = "gold" }; 
  2. JsonSerializer serializer = newJsonSerializer(); 
  3. StringWriter sw = new StringWriter(); 
  4. serializer.Serialize(newJsonTextWriter(sw), p); 
  5. Console.WriteLine(sw.GetStringBuilder().ToString()); 
  6. StringReader sr = newStringReader(@"{""Input"":""stone"",""Output"":""gold""}"); 
  7. Project p1 =(Project)serializer.Deserialize(new JsonTextReader(sr), typeof(Project)); 
  8. Console.WriteLine(p1.Input +"=>" + p1.Output);
Project p = new Project() { Input ="stone", Output = "gold" };
JsonSerializer serializer = newJsonSerializer();
StringWriter sw = new StringWriter();
serializer.Serialize(newJsonTextWriter(sw), p);
Console.WriteLine(sw.GetStringBuilder().ToString()); StringReader sr = newStringReader(@"{""Input"":""stone"",""Output"":""gold""}");
Project p1 =(Project)serializer.Deserialize(new JsonTextReader(sr), typeof(Project));
Console.WriteLine(p1.Input +"=>" + p1.Output);

上面的代码都是基于下面这个Project类定义:

[csharp] view plaincopyprint?

  1. class Project 
  2. publicstring Input { get; set; } 
  3. publicstring Output { get; set; } 
  4. }
class Project
{
public string Input { get; set; }
public string Output { get; set; }
}

此外,如果上面的JsonTextReader等类编译不过的话,说明是我们自己修改过的类,换成你们自己的相关类就可以了,不影响使用。

3. 内置方式

使用.NET Framework 3.5/4.0中提供的System.Web.Script.Serialization命名空间下的JavaScriptSerializer类进行对象的序列化与反序列化,很直接。

[csharp] view plaincopyprint?

  1. Project p = new Project() { Input ="stone", Output = "gold" }; 
  2. JavaScriptSerializer serializer = newJavaScriptSerializer(); 
  3. varjson = serializer.Serialize(p); 
  4. Console.WriteLine(json); 
  5. varp1 = serializer.Deserialize<Project>(json); 
  6. Console.WriteLine(p1.Input+ "=>" + p1.Output); 
  7. Console.WriteLine(ReferenceEquals(p,p1));
 Project p = new Project() { Input ="stone", Output = "gold" };
JavaScriptSerializer serializer = newJavaScriptSerializer();
varjson = serializer.Serialize(p);
Console.WriteLine(json); varp1 = serializer.Deserialize<Project>(json);
Console.WriteLine(p1.Input+ "=>" + p1.Output);
Console.WriteLine(ReferenceEquals(p,p1));

注意:如果使用的是VS2010,则要求当前的工程的Target Framework要改成.Net Framework 4,不能使用Client Profile。当然这个System.Web.Extensions.dll主要是Web使用的,直接在Console工程中用感觉有点浪费资源。

此外,从最后一句也可以看到,序列化与反序列化是深拷贝的一种典型的实现方式。

4. 契约方式

使用System.Runtime.Serialization.dll提供的DataContractJsonSerializer或者JsonReaderWriterFactory实现。

[csharp] view plaincopyprint?

  1. Project p = new Project() { Input ="stone", Output = "gold" }; 
  2. DataContractJsonSerializer serializer = newDataContractJsonSerializer(p.GetType()); 
  3. string jsonText; 
  4. using (MemoryStream stream = newMemoryStream()) 
  5. serializer.WriteObject(stream, p); 
  6. jsonText = Encoding.UTF8.GetString(stream.ToArray()); 
  7. Console.WriteLine(jsonText); 
  8. using (MemoryStream ms = newMemoryStream(Encoding.UTF8.GetBytes(jsonText))) 
  9. DataContractJsonSerializer serializer1 = newDataContractJsonSerializer(typeof(Project)); 
  10. Project p1 = (Project)serializer1.ReadObject(ms); 
  11. Console.WriteLine(p1.Input + "=>" + p1.Output); 
  12. }
Project p = new Project() { Input ="stone", Output = "gold" };
DataContractJsonSerializer serializer = newDataContractJsonSerializer(p.GetType());
string jsonText; using (MemoryStream stream = newMemoryStream())
{
serializer.WriteObject(stream, p);
jsonText = Encoding.UTF8.GetString(stream.ToArray());
Console.WriteLine(jsonText);
} using (MemoryStream ms = newMemoryStream(Encoding.UTF8.GetBytes(jsonText)))
{
DataContractJsonSerializer serializer1 = newDataContractJsonSerializer(typeof(Project));
Project p1 = (Project)serializer1.ReadObject(ms);
Console.WriteLine(p1.Input + "=>" + p1.Output);
}

C# 解析JSON格式数据的更多相关文章

  1. 解析json格式数据

    实现目标 读取文件中的json格式数据,一行为一条json格式数据.进行解析封装成实体类. 通过google的Gson对象解析json格式数据 我现在解析的json格式数据为: {",&qu ...

  2. 实现android上解析Json格式数据功能

    实现android上解析Json格式数据功能,该源码转载于安卓教程网的,http://android.662p.com ,个人感觉还不错的,大家可以看看一下吧. package com.practic ...

  3. 用GSON解析Json格式数据

    GSON是谷歌提供的开源库,用来解析Json格式的数据,非常好用.如果要使用GSON的话,则要先下载gson-2.2.4.jar这个文件,如果是在Android项目中使用,则在Android项目的li ...

  4. $Java-json系列(一):用GSON解析Json格式数据

    GSON是谷歌提供的开源库,用来解析Json格式的数据,非常好用.如果要使用GSON的话,则要先下载gson-2.2.4.jar这个文件,如果是在Android项目中使用,则在Android项目的li ...

  5. ObjectMapper用于将java对象转换为json格式数据以及JSONObject对象解析json格式数据

    ObjectMapper objectMapper = new ObjectMapper(); //反序列化的时候如果多了其他属性,不抛出异常 objectMapper.configure(Deser ...

  6. Android 解析JSON格式数据

    比起XML,JSON主要优势在于它的体积更小,在网络上传输的时候可以更省流量.但缺点在于,它的语义性较差,显示不如XML直观. JSON格式 :  { "name_A" : &qu ...

  7. 【转】C# 解析JSON格式数据

    http://blog.csdn.net/coolszy/article/details/8606803 JSON简介 JSON(全称为JavaScript ObjectNotation) 是一种轻量 ...

  8. C#解析Json格式数据小结

    最近,遇到了一些不同的Json格式的数据,需要做不同处理才能转化为想要得到的结果,这里总结一下. 第一种形式:status中是{}形式,对象 string json = @"{'name': ...

  9. Android中解析JSON格式数据常见方法合集

    待解析的JSON格式的文件如下: [{"id":"5", "version":"1.0", "name&quo ...

随机推荐

  1. Twitter-Snowflake,64位自增ID算法详解

    Twitter-Snowflake算法产生的背景相当简单,为了满足Twitter每秒上万条消息的请求,每条消息都必须分配一条唯一的id,这些id还需要一些大致的顺序(方便客户端排序),并且在分布式系统 ...

  2. 最短路模板(Dijkstra & Dijkstra算法+堆优化 & bellman_ford & 单源最短路SPFA)

    关于几个的区别和联系:http://www.cnblogs.com/zswbky/p/5432353.html d.每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有S个(草儿家到 ...

  3. 尚学堂Spring视频教程(三):Spring Core中的其他特性

    集合装配   如果bean中有一些集合属性,配置文件的配置如下 package com.bjsxt.dao.impl; import java.util.List; import java.util. ...

  4. memset 的实现分析

    memset 是 msvcrt 中的一个函数,其作用和用途是显而易见的,通常是对一段内存进行填充,就其作用本身不具有任何歧义性.但就有人一定要纠结对数组的初始化一定要写成如下形式: int a[... ...

  5. pointer on c

    http://blog.csdn.net/daniel_ice/article/details/6857019 http://www.cppblog.com/cuigang/archive/2008/ ...

  6. Python用法摘要 BY 四喜三顺

    函数的定义:def function_name(parameters):    block    return expression 自带函数:abs(-9)    #取绝对值round(3.4)   ...

  7. 在 Hibernate 中出现 database product name cannot be null 时怎么解决?

    今 天在做一个SH项目结合的时候忽然出现了,这样的错误,我开始也不知道怎么办,便上网查,看一些高手回答都是说,检查 hibernate.cfg.xml 这个配置文件,或是一些其它的配置,于是我便看了一 ...

  8. WPF自动隐藏的消息框(鼠标放上去将一直显示,移开动画继续),提供normal和error两种边框。

    原地址-> http://www.cnblogs.com/yk250/p/5660777.html 介绍:传统的确定,取消,OK,CANCAL之类的对话框太繁琐了,由于项目需要而诞生的仿手机式提 ...

  9. guava – Optional

    过多的使用null可能会导致大量的bugs,Google code 底层代码中,95%的集合类默认不接受null值.对null值,使用快速失败拒绝null比默认接受更好. 另外,null本身的含义很模 ...

  10. mysql连接查询,封装mysql函数

    连接查询 交叉连接语法: select  * | 字段列表 from 表1  cross join 表2 内连接: select *|字段列表 from 左表 inner join 右表 on 左表. ...