您的位置:首页 > 编程语言 > Python开发

python之json处理

2016-05-24 10:21 483 查看
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于JavaScript(Standard ECMA-262 3rd Edition - December 1999)的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。这些特性使JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成。

以上是网上对json的解释,其实只要记住是一种轻量的数据交换格式就可以了,确实方便,可以把数据写入文件中,也可将数据当做字符串使用,但需要注意的是:

1.字符串输入json时,对元素需要使用双引号,单引号容易出错
2.数据写入文件时,需要注意圆括号,也叫小括号,使用json.dump()默认会将有序排列转化为列表存入json文件,所以如果你的数据中有元组的话需要注意这一点
3. json 字符串内部的字典、列表中的元素,如果是字符串的话,必须用双引号


当然,最重要的还是需要先导入json模块:

import json


字符串解析:

json.dumps()    #编码:把一个Python对象编码转换成Json字符串
json.loads()        #解码:把Json格式字符串解码转换成Python对象


栗子:

add_contect_str=‘{"backend": "www.oldboy.org","record":{"server": "100.1.7.9","weight": 20,"maxconn": 3000}}’
add_contect=json.loads(add_contect_str)
search_info=add_contect['backend']
weight=add_contect['record']['weight']
server=add_contect['record']['server']
maxconn=add_contect['record']['maxconn']


文件解析:

文件内容:

{
"汽车": {
"BMW X3": {
"price": 499999,
"stock": 399,
"belong": "汽车"
},
"PASST": {
"price": 299999,
"stock": 297,
"belong": "汽车"
},
"Tesla Model S": {
"price": 799999,
"stock": 3000,
"belong": "汽车"
},
"Porsche 911": {
"price": 2999999,
"stock": 594,
"belong": "汽车"
}
},
"手机": {
"锤子2(这特么真是手机)": {
"price": 998,
"stock": 2994,
"belong": "手机"
},
"华为Mate": {
"price": 2999,
"stock": 5996,
"belong": "手机"
},
"Iphone": {
"price": 5888,
"stock": 2998,
"belong": "手机"
},
"XiaoMi 4": {
"price": 1999,
"stock": 5396,
"belong": "手机"
}
},
"服装": {
"小白鞋": {
"price": 900,
"stock": 5964,
"belong": "服装"
},
"T恤": {
"price": 300,
"stock": 892,
"belong": "服装"
},
"驴牌腰带": {
"price": 9999,
"stock": 2999,
"belong": "服装"
},
"Nudie牛仔裤": {
"price": 699,
"stock": 3978,
"belong": "服装"
}
},
"电脑": {
"Mac Air": {
"price": 6999,
"stock": 6002,
"belong": "电脑"
},
"Mac pro": {
"price": 9999,
"stock": 3995,
"belong": "电脑"
},
"IBM X240": {
"price": 6999,
"stock": 3003,
"belong": "电脑"
},
"Surface Book": {
"price": 8999,
"stock": 3020,
"belong": "电脑"
}
},
"家电": {
"洗衣机": {
"price": 999,
"stock": 597,
"belong": "家电"
},
"彩电": {
"price": 5000,
"stock": 398,
"belong": "家电"
},
"微波炉": {
"price": 800,
"stock": 2995,
"belong": "家电"
},
"冰箱": {
"price": 3000,
"stock": 300,
"belong": "家电"
},
"热水器": {
"price": 600,
"stock": 900,
"belong": "家电"
}
}
}


解析:

user_info=json.load(open('user_info','r'))        #读数据
json.dump(goods,open('goods_info','w'),ensure_ascii=False,indent=1)    #写入数据


其中,ensure_ascii=False表示不转编码,如果数据中有中文,没有ensure_ascii参数时,会转为乱码。indent为缩进,让数据看起来更有序,优雅的装逼法则。

排序:sort_keys=True,排序使数据看起来更有序,虽然字典的是无序的,然并卵。。。

import json
data1 = {'b':789,'c':456,'a':123}
data2 = {'a':123,'b':789,'c':456}
d1 = json.dumps(data1,sort_keys=True)
d2 = json.dumps(data2)
d3 = json.dumps(data2,sort_keys=True)
print(d1)
print(d2)
print(d3)
print(d1==d2)


结果:

{"a": 123, "b": 789, "c": 456}
{"c": 456, "b": 789, "a": 123}
{"a": 123, "b": 789, "c": 456}
False
[Finished in 0.1s]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: