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

基于JSON数据格式详解,JSON数据格式详解

JSON是行业内使用最为广泛的数据交换格式,在很多场景都有广泛的应用。JSON适用于进行数据交互的场景,典型的是Ajax中实现异步加载;为了支持跨平台、数据安全等的Web
Service也可以使用(API接口返回值)。

JSON(JavaScript Object
Notation)是一种完全独立于语言的、轻量级的数据交换格式。它基于JavaScript
Programming Language, Standard ECMA-262 3rd Edition – December
1999的一个子集。JSON的官方MIME类型是application/json,文件扩展名是
.json。

优点:易于人阅读和编写。同时也易于机器解析和生成。支持众多语言。

JSON建构于两种结构:

· “名称/值”对的集合(A collection of name/value
pairs)。不同的语言中,它被理解为对象(object),纪录(record),结构(struct),字典(dictionary),哈希表(hash
table),有键列表(keyed list),或者关联数组 (associative array)。

· 值的有序列表(An ordered list of
values)。在大部分语言中,它被理解为数组(array)。

JSON具有以下这些形式:

Object是一个无序的“‘名称/值’对”集合。一个对象以“{”开始,“}”结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’
对”之间使用“,”分隔。

Array是值(value)的有序集合。一个数组以“[”开始,“]”结束。值之间使用“,”分隔。

值(value)可以是双引号括起来的字符串(string)、数值(number)、true、false、
null、对象(object)或者数组(array)。这些结构可以嵌套。

基本类型:

string、number、 true、false、 null。

字符串(string)是由双引号包围的任意数量Unicode字符的集合,使用反斜线转义。一个字符(character)即一个单独的字符串(character
string)。

JSON实例

{
 "name":"Python学习者",
 "age":20,
 "course":["Java","Python"],
 "job":null,
 "url":"http://www.bkjia.com"
}

JavaScript

<html>
<head>
 <meta charset="utf-8">
 <title>Pyhton学习者-JSON</title>
</head>
<body>
 <p>使用" . "访问JSON对象</p>
 <p id="demo1"></p>
 <p>使用" [] "访问JSON对象</p>
 <p id="demo2"></p>

<script>
 var obj, name, age;
 obj =  {
  "name":"Python学习者",
  "age":20,
  "course":["Java","Python"],
  "job":null,
  "url":"http://www.bkjia.com"
 }
 name = obj.name;
 document.getElementById("demo1").innerHTML = name;
 age = obj["age"];
 document.getElementById("demo2").innerHTML = age;
</script>

</body>
</html>

MongoDB

MongoDB是一种常用的NoSQL数据库,它所有的信息都是按照文档保存的,保存的结构就是JSON结构。

db.students.insert({"name" : "张三" , "sex" : "男" , "age" : 18 , "score" : 85 });
db.students.insert({"name" : "李四" , "sex" : "女" , "age" : 21 , "score" : 93 });
db.students.insert({"name" : "王五" , "sex" : "女" , "age" : 19 , "score" : 68 });
db.students.find("name":"张三");

其实JSON结构并不难理解,需要注意的是”key/value”中,key是string类型,要使用
“”(双引号)。

参考资料:

在线代码格式化:

JSON官方网站:

以上这篇基于JSON数据格式详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持帮客之家。

JSON是行业内使用最为广泛的数据交换格式,在很多场景都有广泛的应用。JSON适用于进行数据交互…

转自:

        要想熟练的操作json数据,就要先了解json数据:

JSON 数据格式

       JSON(JavaScript Object Notation)
是一种轻量级的数据交换格式。JSON采用完全独立于语言的文本格式,这些特性使JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成。

       
JSON的规则很简单:对象是一个无序的“‘名称/值’对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’对”之间使用“,”(逗号)分隔。

基础结构

JSON建构于两种结构:

  1. “名称/值”对的集合(A collection of name/value
    pairs)。不同的语言中,它被理解为对象(object),记录(record),结构(struct),字典(dictionary),哈希表(hash
    table),有键列表(keyed list),或者关联数组 (associative array)。

  2. 值的有序列表(An ordered list of
    values)。在大部分语言中,它被理解为数组(array)。

 

         规则如下:

基础示例

简单地说,JSON 可以将 JavaScript
对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从
Web 客户机传递给服务器端程序。这个字符串看起来有点儿古怪,但是
JavaScript 很容易解释它,而且 JSON 可以表示比”名称 /
值对”更复杂的结构。例如,可以表示数组和复杂的对象,而不仅仅是键和值的简单列表。

1、映射用冒号(“:)表示。名称:值

2、并列的数据之间用逗号(“,”)分隔。名称1:值1,名称2:值2

表示名称 / 值对

按照最简单的形式,可以用下面这样的 JSON 表示 “名称 / 值对” :{ “firstName”: “Brett” }

这个示例非常基本,而且实际上比等效的纯文本 “名称 / 值对”
占用更多的空间:firstName=Brett

但是,当将多个”名称 / 值对”串在一起时,JSON
就会体现出它的价值了。首先,可以创建包含多个”名称 / 值对”的 记录,比如:

{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “aaaa” }

从语法方面来看,这与”名称 / 值对”相比并没有很大的优势,但是在这种情况下
JSON
更容易使用,而且可读性更好。例如,它明确地表示以上三个值都是同一记录的一部分;花括号使这些值有了某种联系。

3、映射的集合(对象)用大括号(“{}”)表示。

{

表示数组

当需要表示一组值时,JSON
不但能够提高可读性,而且可以减少复杂性。例如,假设您希望表示一个人名列表。在
XML 中,需要许多开始标记和结束标记;如果使用典型的 名称 / 值
对(就像在本系列前面文章中看到的那种名称 /
值对),那么必须建立一种专有的数据格式,或者将键名称修改为
person1-firstName这样的形式。

如果使用 JSON,就只需将多个带花括号的记录分组在一起:

{ “people”: [

{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “aaaa” },

{ “firstName”: “Jason”, “lastName”:”Hunter”, “email”: “bbbb”},

{ “firstName”: “Elliotte”, “lastName”:”Harold”, “email”: “cccc” }

]}

这不难理解。在这个示例中,只有一个名为
people的变量,值是包含三个条目的数组,每个条目是一个人的记录,其中包含名、姓和电子邮件地址。上面的示例演示如何用括号将记录组合成一个值。当然,可以使用相同的语法表示多个值(每个值包含多个记录):

{ “programmers”: [

{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “aaaa” },

{ “firstName”: “Jason”, “lastName”:”Hunter”, “email”: “bbbb” },

{ “firstName”: “Elliotte”, “lastName”:”Harold”, “email”: “cccc” }

],

“authors”: [

{ “firstName”: “Isaac”, “lastName”: “Asimov”, “genre”: “science
fiction” },

{ “firstName”: “Tad”, “lastName”: “Williams”, “genre”: “fantasy” },

{ “firstName”: “Frank”, “lastName”: “Peretti”, “genre”: “christian
fiction” }

],

“musicians”: [

{ “firstName”: “Eric”, “lastName”: “Clapton”, “instrument”: “guitar”
},

{ “firstName”: “Sergei”, “lastName”: “Rachmaninoff”, “instrument”:
“piano” }

] }

这里最值得注意的是,能够表示多个值,每个值进而包含多个值。但是还应该注意,在不同的主条目(programmers、authors
和 musicians)之间,记录中实际的名称 / 值对可以不一样。JSON
是完全动态的,允许在 JSON 结构的中间改变表示数据的方式。

在处理 JSON
格式的数据时,没有需要遵守的预定义的约束。所以,在同样的数据结构中,可以改变表示数据的方式,甚至可以以不同方式表示同一事物。

 

名称1:值1,

格式应用

掌握了 JSON 格式之后,在 JavaScript 中使用它就很简单了。JSON 是
JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON
数据不需要任何特殊的 API 或工具包。

名称2:值2

}

将 JSON 数据赋值给变量

例如,可以创建一个新的 JavaScript 变量,然后将 JSON
格式的数据字符串直接赋值给它:

var people = { “programmers”: [ { “firstName”: “Brett”,
“lastName”:”McLaughlin”, “email”: “aaaa” },

{ “firstName”: “Jason”, “lastName”:”Hunter”, “email”: “bbbb” },

{ “firstName”: “Elliotte”, “lastName”:”Harold”, “email”: “cccc” }

],

“authors”: [

{ “firstName”: “Isaac”, “lastName”: “Asimov”, “genre”: “science
fiction” },

{ “firstName”: “Tad”, “lastName”: “Williams”, “genre”: “fantasy” },

{ “firstName”: “Frank”, “lastName”: “Peretti”, “genre”: “christian
fiction” }

],

“musicians”: [

{ “firstName”: “Eric”, “lastName”: “Clapton”, “instrument”: “guitar”
},

{ “firstName”: “Sergei”, “lastName”: “Rachmaninoff”, “instrument”:
“piano” }

] }

这非常简单;现在 people包含前面看到的 JSON
格式的数据。但是,这还不够,因为访问数据的方式似乎还不明显。

 

4、并列数据的集合(数组)用方括号(“[]”)表示。

访问数据

尽管看起来不明显,但是上面的长字符串实际上只是一个数组;将这个数组放进
JavaScript
变量之后,就可以很轻松地访问它。实际上,只需用点号表示法来表示数组元素。所以,要想访问
programmers 列表的第一个条目的姓氏,只需在 JavaScript
中使用下面这样的代码:

people.programmers[0].lastName;

注意,数组索引是从零开始的。所以,这行代码首先访问
people变量中的数据;然后移动到称为
programmers的条目,再移动到第一个记录([0]);最后,访问
lastName键的值。结果是字符串值 “McLaughlin”。

下面是使用同一变量的几个示例。

people.authors[1].genre // Value is “fantasy”

people.musicians[3].lastName // Undefined. This refers to the fourth
entry, and there isn’t one

people.programmers[2].firstName // Value is “Elliotte”

利用这样的语法,可以处理任何 JSON 格式的数据,而不需要使用任何额外的
JavaScript 工具包或 API。

 

[

修改 JSON 数据

正如可以用点号和括号访问数据,也可以按照同样的方式轻松地修改数据:

people.musicians[1].lastName = “Rachmaninov”;

在将字符串转换为 JavaScript 对象之后,就可以像这样修改变量中的数据。

 

{名称1:值,名称2:值2},

转换回字符串

当然,如果不能轻松地将对象转换回本文提到的文本格式,那么所有数据修改都没有太大的价值。在
JavaScript 中这种转换也很简单:

String newJSONtext = people.toJSONString();

这样就行了!现在就获得了一个可以在任何地方使用的文本字符串,例如,可以将它用作
Ajax 应用程序中的请求字符串。

更重要的是,可以将任何JavaScript 对象转换为 JSON
文本。并非只能处理原来用 JSON 字符串赋值的变量。为了对名为
myObject的对象进行转换,只需执行相同形式的命令:

String myObjectInJSON = myObject.toJSONString();

这就是 JSON 与本系列讨论的其他数据格式之间最大的差异。如果使用
JSON,只需调用一个简单的函数,就可以获得经过格式化的数据,可以直接使用了。对于其他数据格式,需要在原始数据和格式化数据之间进行转换。即使使用
Document Object Model 这样的
API(提供了将自己的数据结构转换为文本的函数),也需要学习这个 API 并使用
API 的对象,而不是使用原生的 JavaScript 对象和语法。

最终结论是,如果要处理大量 JavaScript 对象,那么 JSON
几乎肯定是一个好选择,这样就可以轻松地将数据转换为可以在请求中发送给服务器端程序的格式。

 

{名称1:值,名称2:值2}

概念比较

JSON和XML的比较

可读性

JSON和XML的可读性可谓不相上下,一边是简易的语法,一边是规范的标签形式,很难分出胜负。

可扩展性

XML天生有很好的扩展性,JSON当然也有,没有什么是XML能扩展,而JSON却不能。不过JSON在Javascript主场作战,可以存储Javascript复合对象,有着xml不可比拟的优势。

编码难度

XML有丰富的编码工具,比如Dom4j、JDom等,JSON也有提供的工具。无工具的情况下,相信熟练的开发人员一样能很快的写出想要的xml文档和JSON字符串,不过,xml文档要多很多结构上的字符。

解码难度

XML的解析方式有两种:

一是通过文档模型解析,也就是通过父标签索引出一组标记。例如:xmlData.getElementsByTagName(“tagName”),但是这样是要在预先知道文档结构的情况下使用,无法进行通用的封装。

另外一种方法是遍历节点(document 以及
childNodes)。这个可以通过递归来实现,不过解析出来的数据仍旧是形式各异,往往也不能满足预先的要求。

凡是这样可扩展的结构数据解析起来一定都很困难。

JSON也同样如此。如果预先知道JSON结构的情况下,使用JSON进行数据传递简直是太美妙了,可以写出很实用美观可读性强的代码。如果你是纯粹的前台开发人员,一定会非常喜欢JSON。但是如果你是一个应用开发人员,就不是那么喜欢了,毕竟xml才是真正的结构化标记语言,用于进行数据传递。

而如果不知道JSON的结构而去解析JSON的话,那简直是噩梦。费时费力不说,代码也会变得冗余拖沓,得到的结果也不尽人意。但是这样也不影响众多前台开发人员选择JSON。因为json.js中的toJSONString()就可以看到JSON的字符串结构。当然不是使用这个字符串,这样仍旧是噩梦。常用JSON的人看到这个字符串之后,就对JSON的结构很明了了,就更容易的操作JSON。

以上是在Javascript中仅对于数据传递的xml与JSON的解析。在Javascript地盘内,JSON毕竟是主场作战,其优势当然要远远优越于xml。如果JSON中存储Javascript复合对象,而且不知道其结构的话,我相信很多程序员也一样是哭着解析JSON的。

实例比较

XML和JSON都使用结构化方法来标记数据,下面来做一个简单的比较。

用XML表示中国部分省市数据如下:

<?xml version=”1.0″ encoding=”utf-8″?>

<country>

    <name>中国</name>

    <province>

        <name>黑龙江</name>

     <cities>

            <city>哈尔滨</city>

            <city>大庆</city>

        </cities>

    </province>

    <province>

        <name>广东</name>

        <cities>

            <city>广州</city>

            <city>深圳</city>

            <city>珠海</city>

        </cities>

    </province>

</country>

 

用JSON表示如下:

{

{name:”中国”, province:[ { name:”黑龙江”, cities:{
city:[“哈尔滨”,”大庆”] },

{name:”广东”, cities:{ city:[“广州”,”深圳”,”珠海”] } 

}

编码的可读性,xml有明显的优势,毕竟人类的语言更贴近这样的说明结构。json读起来更像一个数据块,读起来就比较费解了。不过,我们读起来费解的语言,恰恰是适合机器阅读,所以通过json的索引.province[0].name就能够读取“黑龙江”这个值。

编码的手写难度来说,xml还是舒服一些,好读当然就好写。不过写出来的字符JSON就明显少很多。去掉空白制表以及换行的话,JSON就是密密麻麻的有用数据,而xml却包含很多重复的标记字符。

 

]

JSON在线校验工具

5、元素值可具有的类型:string,number, object, array, true, false, null

前言

JSON格式取代了xml给网络传输带来了很大的便利,但是却没有了xml的一目了然,尤其是json数据很长的时候,我们会陷入繁琐复杂的数据节点查找中。

但是国人的一款在线工具 BeJson 给众多程序员带来了一阵凉风。

注意:1、JSON
用冒号(而不是等号)来赋值。每一条赋值语句用逗号分开。整个对象用大括号封装起来。可用大括号分级嵌套数据。

功能简介

1. JSON格式化校验

很多人在得到JSON数据后,一时没有办法判断JSON数据格式是否正确,是否少或多符号而导致程序不能解析,这个功能正好能帮助大家来完成JSON格式的校验。

2. JSON视图

想必很多程序员都会遇到当找一个节点的时候,会发现如果直接对着一行行数据无从下手,就算知道哪个位置,还要一个节点一个节点的往下找,万一一不留神又得从头开始找的麻烦事。

有了这个功能,一切JSON数据都会变成视图格式,一目了然,什么对象下有多少数组,一个数组下有多少对象。

这个功能非常实用。不光有视图功能还有格式化、压缩、转义、校验功能。总之很强大。

3. 压缩转义

程序员在写JSON语句测试用例的时候,很多时候为了方便直接写了个JSON字符串做测试,但是又陷入了无止境的双引号转义的麻烦中。这款功能集压缩、转义于一身,让你在写测试用例的时候,如鱼得水。

4. JSON在线编辑器

如果你现在的电脑刚巧没有装你所熟悉的编辑器,如果你想针对拿到的JSON数据的某个节点做数据修改时,这个功能可以满足你的需求。

5. 在线发送JSON数据

大家都知道,JSON用的最多的还是web项目的开发,那你要测试一个接口是否能准确的接受JSON数据,那你就得写一个页面发送JSON字符串,重复的做着这件事。随着这个功能的横空出世,你可以摆脱写测试页面了,因为这个功能可以将指定的JSON数据发送指定的url,方便吧。

6. JSON着色

很多人在写文档时,总希望文档能一目了然,但是面对着白底黑字的JSON数据总是提不起精神没关系,使用这个功能,所有的关键字都会被着色,数据结构一目了然。

7. JSON-XML互转

顾名思义,将JSON格式的数据转化成XML格式、或者XML格式的数据转化成JSON格式,一切都不是问题。

           
 2、对象描述中存储的数据可以是字符串,数字或者布尔值。对象描述也可存储函数,那就是对象的方法。

6、JSON主要有两种数据结构

(1)由key–value对组成的数据结构。这种数据结构在不同的语言中有不同的实现.

例如:在javascript中是一个对象.而在java中是一种Map结构,c语言中是struct,其它的语言中可能为record、
hash table 等。

(2)有序集合、这种数据结构在不同语言中可能有list、vertor、数组和序列等实现。

7、C#中json数据格式的处理

List<T>转Json

[csharp]  

public static string Obj2Json<T>(T data)  

{  

    try  

    {  

        System.Runtime.Serialization.Json.DataContractJsonSerializer
serializer = new
System.Runtime.Serialization.Json.DataContractJsonSerializer(data.GetType());
 

        using (MemoryStream ms = new MemoryStream())  

        {  

            serializer.WriteObject(ms, data);  

            return Encoding.UTF8.GetString(ms.ToArray());  

        }  

    }  

    catch  

    {  

        return null;  

    }  

}  

 

Json转List<T>

[csharp]  

public static Object Json2Obj(String json,Type t)  

{  

    try  

    {  

        System.Runtime.Serialization.Json.DataContractJsonSerializer
serializer = new
System.Runtime.Serialization.Json.DataContractJsonSerializer(t);  

        using (MemoryStream ms = new
MemoryStream(Encoding.UTF8.GetBytes(json)))  

        {  

              

            return  serializer.ReadObject(ms);  

        }  

    }  

    catch  

    {  

        return null;  

    }  

}  

 

DataTable 转Json

[csharp]  

public static string DataTable2Json(DataTable dt)  

{  

    if (dt.Rows.Count == 0)  

    {  

        return “”;  

    }  

   

    StringBuilder jsonBuilder = new StringBuilder();  

    // jsonBuilder.Append(“{“);   

    //jsonBuilder.Append(dt.TableName.ToString());    

    jsonBuilder.Append(“[“);//转换成多个model的形式  

    for (int i = 0; i < dt.Rows.Count; i++)  

    {  

        jsonBuilder.Append(“{“);  

        for (int j = 0; j < dt.Columns.Count; j++)  

        {  

            jsonBuilder.Append(“\””);  

            jsonBuilder.Append(dt.Columns[j].ColumnName);  

            jsonBuilder.Append(“\”:\””);  

            jsonBuilder.Append(dt.Rows[i][j].ToString());  

            jsonBuilder.Append(“\”,”);  

        }  

        jsonBuilder.Remove(jsonBuilder.Length – 1, 1);  

        jsonBuilder.Append(“},”);  

    }  

    jsonBuilder.Remove(jsonBuilder.Length – 1, 1);  

    jsonBuilder.Append(“]”);  

    //  jsonBuilder.Append(“}”);  

    return jsonBuilder.ToString();  

}  

 

单个对象转JSON

 

[csharp]  

public static T Json2Obj<T>(string json)   

{  

    T obj = Activator.CreateInstance<T>();  

    using (System.IO.MemoryStream ms = new
System.IO.MemoryStream(System.Text.Encoding.UTF8.GetBytes(json)))  

    {  

        System.Runtime.Serialization.Json.DataContractJsonSerializer
serializer = new
System.Runtime.Serialization.Json.DataContractJsonSerializer(obj.GetType());
 

        return (T)serializer.ReadObject(ms);  

    }  

}  

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图