JSON即JavaScript Object Natation,它是一种轻量级的数据交换格式,非常适合服务器与JavaScript的交互。JSON易于人阅读和编写。同时也易于机器解析和生成。JSON采用完全独立语言的文本格式,但是也是用了类似于C语言家族的习惯(包括C,C++,C#,JAVA,JavaScript,Perl,Python等)。这些特性使JSON成为理想的数据交换语言。
XML也是一种数据交换格式,不过XML标记比较多,往往使得标记比需要传递的数据都还多,这样会增加字符传输的负担。
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)。
Python的json模块提供了一种很简单的方式来编码和解码JSON数据。 其中两个主要的函数是 json.dumps() 和 json.loads() , 要比其他序列化函数库如pickle的接口少得多。 下面演示如何将一个Python数据结构转换为JSON:
import
json
data
=
{
'name'
:
'ACME'
,
'shares'
:
100
,
'price'
:
542.23
}
json_str
=
json.dumps(data)
# Writing JSON data
with
open
(
'data.json'
,
'w'
) as f:
json.dump(data, f)
# Reading data back
with
open
(
'data.json'
,
'r'
) as f:
data
=
json.load(f)
json.dumps 与 json.loads 实例
以下实例演示了 Python 数据结构转换为JSON:
#!/usr/bin/python3import json# Python 字典类型转换为 JSON 对象data = { 'no' : 1, 'name' : 'W3CSchool', 'url' : 'http://www.w3cschool.cn'}json_str = json.dumps(data)print ("Python 原始数据:", repr(data))print ("JSON 对象:", json_str)
执行以上代码输出结果为:
Python 原始数据: {'url': 'http://www.w3cschool.cn', 'no': 1, 'name': 'W3CSchool'}JSON 对象: {"url": "http://www.w3cschool.cn", "no": 1, "name": "W3CSchool"}
通过输出的结果可以看出,简单类型通过编码后跟其原始的repr()输出结果非常相似。
接着以上实例,我们可以将一个JSON编码的字符串转换回一个Python数据结构:
#!/usr/bin/python3import json# Python 字典类型转换为 JSON 对象data1 = { 'no' : 1, 'name' : 'W3CSchool', 'url' : 'http://www.w3cschool.cn'}json_str = json.dumps(data1)print ("Python 原始数据:", repr(data1))print ("JSON 对象:", json_str)# 将 JSON 对象转换为 Python 字典data2 = json.loads(json_str)print ("data2['name']: ", data2['name'])print ("data2['url']: ", data2['url'])
执行以上代码输出结果为:
ython 原始数据: {'name': 'W3CSchool', 'no': 1, 'url': 'http://www.w3cschool.cn'}JSON 对象: {"name": "W3CSchool", "no": 1, "url": "http://www.w3cschool.cn"}data2['name']: W3CSchooldata2['url']: http://www.w3cschool.cn
如果你要处理的是文件而不是字符串,你可以使用 json.dump() 和 json.load() 来编码和解码JSON数据。例如:
# 写入 JSON 数据with open('data.json', 'w') as f: json.dump(data, f)# 读取数据with open('data.json', 'r') as f: data = json.load(f)
1> XML
优点:\u2028-
格式统一, 符合标准\u2028
-
容易与其他系统进行远程交互, 数据共享比较方便
\u2028 缺点:
-
XML文件格式文件庞大, 格式复杂, 传输占用带宽\u2028
-
服务器端和客户端都需要花费大量代码来解析XML, 不论服务器端和客户端代码变的异常复杂和不容易维护
-
客户端不同,浏览器之间解析XML的方式不一致, 需要重复编写很多代码\u2028
-
服务器端 和 客户端 解析XML花费资源和时间
2> JSON
优点:\u2028-
数据格式比较简单, 易于读写, 格式都是压缩的, 占用带宽小\u2028
-
易于解析这种语言
-
支持多种语言, 包括ActionScript, C, C#, ColdFusion, Java, JavaScript, Perl, PHP, Python, Ruby等语言服务器端语言, 便于服务器端的解析\u2028
-
因为JSON格式能够直接为服务器端代码使用, 大大简化了服务器端和客户端的代码开发量, 但是完成的任务不变, 且易于维护\u2028
缺点:\u2028
-
没有XML格式这么推广的深入人心和使用广泛, 没有XML那么通用性\u2028
-
JSON格式目前在Web Service中推广还属于初级阶段
2.JSON、XML解析方式的底层实现
1> XML
Xml两种解析方式,DOM 和 SAX。
DOM 需要读入整个XML文档(文档驱动),SAX 是事件驱动的,并不需要读入整个文档,文档的读入过程也就是SAX的解析过程。
SAX 简单地说就是对XML文档进行顺序扫描,当扫描到 文档 的 开始 与 结束 ,元素(element)的 开始 与 结束 时,就会触发相应的事件处理 函数,由事件处理函数做相应的动作,处理完后继续扫描,直到文档结束,则解析完毕
DOM 解析XML文件时,会将XML文件的所有内容读取到内存中,然后允许你使用 DOM API 操作 XML 树。也就是说,DOM 会把XML以 树 的形式读取到内存中,然后在通过相应的 API 来操作这个 XML树,从而达到解析XML文件的目的
2> JSON
json底层原理 遍历字符串中的字符,最终根据特助字符,比如{},[],:号等进行区分,{}是字典,[]表示的是数组,:号是字典的键和值的分水岭,最后是将json数据转化为字典,然后使用 将字典转为 model
1)对于复杂的数据结构使用XML,简单的数据结构可采用JSON。
2)在互联网应用中数据传输中,提倡使用JSON。