python中json操作了解
- 什么是接口?
交换数据
http://openweathermap.org/current
- json简介
JSON 是存储和交换文本信息的语法。类似 XML
JSON 语法是 JavaScript 语法的子集
- Json语法规则
数据在名称、值对中
数据由逗号分隔
花括号保存对象
方括号保存数组
Json的值可以是:
数字(整数或浮点数)
字符串(在双括号中)
逻辑值(true或false)
数组(在方括号中)
对象(在花括号中)
Null
- json串转换
Python的json模块序列化和反序列化分别是dumps和loads。
➢json.dumps():将一个Python对象编码成JSON字符串。
➢json.loads():将JSON格式字符串解码成Python对象。
>>> import json
>>> json.dumps({1:2})
'{"1": 2}'
>>> json.dumps({"a":2})
'{"a": 2}'
>>> json.dumps({True:2})
'{"True": 2}'
>>> print type(json.dumps({True:2}))
<type 'str'>
字典的key会默认转成字符串,整个类型其实就是字符串类型。
>>> json.dumps((1,2,3))
'[1, 2, 3]'
>>> json.dumps((1))
'1'
>>> json.dumps([1,2,3])
'[1, 2, 3]'
>>> json.dumps(True)
'true'
>>> json.dumps(False)
'false'
>>> json.dumps(None)
'null'
>>> json.dumps("abc")
'"abc"'
>>> json.dumps([{"a":1,"b":1}])
'[{"a": 1, "b": 1}]'
>>> json.dumps([{"a":1,"b":1},{"c":3}])
'[{"a": 1, "b": 1}, {"c": 3}]'
>>>
转换字典类型的最为常用。
整体练习例子:
#coding=utf-8
import json
a = [{1:12, 'a':12.3}, [1,2,3], (1,2), 'asd', u'ad', 12, 13L, 3.3, True, False, None]
print u"Python类型:\n", a
print u"编码后的json串:\n", json.dumps(a)
- json.dumps() 加sortkey的作用: 是否按字典排序(a到z)输出。因为默认编码成json格式字符串后,是紧凑输出,并且也没有顺序的,不利于可读。
#coding=utf-8
import json
data = [ { 'a':'A', 'b':(2, 4), 'c':3.0 }]
print json.dumps(data)
print json.dumps(data, sort_keys=True)
结果:
E:\>python a.py
[{"a": "A", "c": 3.0, "b": [2, 4]}]
[{"a": "A", "b": [2, 4], "c": 3.0}]
- json.dumps() indent设置参数缩进显示的空格数,控制输出格式。
#coding=utf-8
import json
data = [{"a": "A", "b": [2, 4], "c": 3.0}]
print json.dumps(data, sort_keys=True, indent=3)
这里的缩进是每行都有的
- json.dumps() separator作用是去掉逗号“ ,” 和分号“ :” 后面的空格
#coding=utf-8
import json
data = [{"a": "A", "b": [2, 4], "c": 3.0}]
print len(json.dumps(data))
# 去掉编码后的json串中,和:后面的空格
print len(json.dumps(data, separators=(',',':')))
- json.dumps() skipkeys在encoding过程中,dict对象的key只可以是基本数据类型(str,unicode,int,long,float,bool,None),如果是其他类型,那么在编码过程中就会抛出TypeError的异常。 skipkeys可以跳过那些非string对象的key的处理,就是不处理。
#coding=utf-8
import json
data= [ { 'a':'A', 'b':(2, 4), 'c':3.0, (1,2):'D tuple' } ]
print u"不设置skipkeys 参数"
try :
res1 = json.dumps(data) #skipkeys参数默认为False时
except Exception, e:
print e
print u"设置skipkeys 参数"
print json.dumps(data, skipkeys=True)# skipkeys=True时
- dumps()的作用,由于python只在自己的编译环境中有效,这里用dumps()把python的对象转换成服务器能够识别的字符串。
- json.loads 将简单数据类型解码成python
#coding=utf-8
import json
data = [{'a':"Aasdf",'b':(2,4),'c':3.0}]
data_json = json.dumps(data)
print "encoding :", data_json
print "decoding :", json.loads(data_json)
结果:
E:\>python a.py
encoding : [{"a": "Aasdf", "c": 3.0, "b": [2, 4]}]
decoding : [{u'a': u'Aasdf', u'c': 3.0, u'b': [2, 4]}]
结果中的unicode怎么转换成string类型?
方法一:直接str()
>>> type(str(u"a"))
<type 'str'>
方法二:encode
>>> type(u"a".encode("gbk"))
<type 'str'>
小练习:
encoding : [{"a": "Aasdf", "c": 3.0, "b": [2, 4]}]
decoding : [{u'a': u'Aasdf', u'c': 3.0, u'b': [2, 4]}]
如何把decoding中的u去掉?
老师的方法:
#coding=utf-8
import json
data = [{'a':"Aasdf",'b':(2,4),'c':3.0}]
data_json = json.dumps(data)
print "encoding :", data_json
print "decoding :", json.loads(data_json)
s= json.loads(data_json)
d=s[0]
new_d={}
new_list=[]
for k,v in d.items():
if isinstance(v,unicode):
new_d[str(k)]=str(v)
else:
new_d[str(k)]=v
new_list.append(new_d)
print new_list
同学的方法:更严谨的判定逻辑
for key,value in dict_a.items():
if isinstance(key,unicode) and isinstance(value,unicode):
result[str(key)]=str(value)
elif isinstance(key,unicode) and not isinstance(value,unicode):
result[str(key)]=value
elif not isinstance(key,unicode) and isinstance(value,unicode):
result[key]=str(value)
elif not isinstance(key,unicode) and not isinstance(value,unicode):
result[key]=value
return result
- Json到python类型转换:转换回来的类型中是没有tuple的,转换后都是unicode类型。
>>> json.loads('1')
1
>>> json.loads('{"a":"1"}')
{u'a': u'1'}
>>> json.loads('["1","2"]')
[u'1', u'2']
>>> json.loads('1.2')
1.2
>>> json.loads('true')
True
>>> json.loads('false')
False
>>> json.loads('null')
>>> type(json.loads('null'))
例题:json转python
#coding=utf-8
import json
a = [{1:12, 'a':12.3}, [1,2,3], (1,2), 'asd', u'ad', 12, 13L, 3.3, True, False, None]
print u"编码后\n", json.dumps(a)
print u"解码后\n", json.loads(json.dumps(a))
结果:
E:\>python a.py
编码后
[{"a": 12.3, "1": 12}, [1, 2, 3], [1, 2], "asd", "ad", 12, 13, 3.3, true, false,null]
解码后
[{u'a': 12.3, u'1': 12}, [1, 2, 3], [1, 2], u'asd', u'ad', 12, 13, 3.3, True, False, None]
- 将类对象转换成json串
方法一:
#encoding=utf-8
import json
class Employee(object):
def __init__(self, name, age, sex, tel):
self.name = name
self.age = age
self.sex = sex
self.tel = tel
# 将序列化函数定义到类里面
def obj_json(self, obj_instance):
return {
'name': obj_instance.name,
'age': obj_instance.age,
'sex': obj_instance.sex,
'tel': obj_instance.tel
}
emp = Employee('Lily', 24, 'female', '18223423423') 返回成一个字典
print json.dumps(emp, default = emp.obj_json)
结果:
E:\>python a.py
{"age": 24, "tel": "18223423423", "name": "Lily", "sex": "female"}
方法一中的类变形:
#encoding=utf-8
import json
class Employee(object):
def __init__(self, name, age, sex, tel):
self.name = name
self.age = age
self.sex = sex
self.tel = tel
# 将序列化函数定义到类里面
def obj_json(self):
return {
'name': self.name ,
'age': self.age,
'sex': self.sex,
'tel': self.tel
}
emp = Employee('Lily', 24, 'female', '18223423423')
print json.dumps(emp.obj_json())
方法二:先转成dict,然后再被序列化成json串。
#encoding=utf-8
import json
class Employee(object):
def __init__(self, name, age, sex, tel):
self.name = name
self.age = age
self.sex = sex
self.tel = tel
emp = Employee('Lily', 24, 'female', '18223423423')
print emp.__dict__
print(json.dumps(emp, default = lambda Employee: Employee.__dict__))
print(json.dumps(emp, default = lambda emp: emp.__dict__))
结果:
E:\>python a.py
{'age': 24, 'tel': '18223423423', 'name': 'Lily', 'sex': 'female'}
{"age": 24, "tel": "18223423423", "name": "Lily", "sex": "female"}
{"age": 24, "tel": "18223423423", "name": "Lily", "sex": "female"}
- json反序列化为类对象
#encoding=utf-8
import json
class Employee(object):
def __init__(self, name, age, sex, tel):
self.name = name
self.age = age
self.sex = sex
self.tel = tel
emp = Employee('Lily', 24, 'female', '18223423423')
def jsonToClass(emp):
return Employee(emp['name'], emp['age'], emp['sex'], emp['tel'])
json_str = '{"name": "Lucy", "age": 21, "sex": "female", "tel": "15834560985"}'
e = json.loads(json_str, object_hook = jsonToClass)
print e
print e.name
object_hook = jsonToClass 命名参数传递
结果:
E:\>python a.py
<__main__.Employee object at 0x01AF5970>
Lucy
python中json操作了解的更多相关文章
- python中json操作
1.写操作.json文件dumps().dump()函数 d = { 'zll': { 'addr': '北京', 'age': 28 }, 'ljj': { 'addr': '北京', 'age': ...
- Python中json的简单读写操作
Python中json的简单读写操作 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的 ...
- Neo4j:图数据库GraphDB(四)Python中的操作
本文总结下Python中如何操作Neo4j数据库,用到py2neo包,Pip install 一下. 1 连接neo4j数据库:跟其它数据库一样,操作前必须输入用户名和密码及地址连接一下. from ...
- python中json格式数据输出实现方式
python中json格式数据输出实现方式 主要使用json模块,直接导入import json即可. 小例子如下: #coding=UTF-8 import json info={} info[&q ...
- python中文件操作的六种模式及对文件某一行进行修改的方法
一.python中文件操作的六种模式分为:r,w,a,r+,w+,a+ r叫做只读模式,只可以读取,不可以写入 w叫做写入模式,只可以写入,不可以读取 a叫做追加写入模式,只可以在末尾追加内容,不可以 ...
- python中文件操作的其他方法
前面介绍过Python中文件操作的一般方法,包括打开,写入,关闭.本文中介绍下python中关于文件操作的其他比较常用的一些方法. 首先创建一个文件poems: p=open('poems','r', ...
- python MySQLdb用法,python中cursor操作数据库(转)
数据库连接 连接数据库前,请先确认以下事项: 您已经创建了数据库 TESTDB. 在TESTDB数据库中您已经创建了表 EMPLOYEE EMPLOYEE表字段为 FIRST_NAME, LAST_N ...
- (数据科学学习手札126)Python中JSON结构数据的高效增删改操作
本文示例代码及文件已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 在上一期文章中我们一起学习了在Python ...
- python中json的操作示例
先上一段示例 # -*- coding: cp936 -*- import json #构造一个示例数据,并打印成易读样式 j = {} j["userName"]="a ...
随机推荐
- Eclipse IDE配置PHP开发、调试环境
前言 使用java语言开发的朋友想必对Eclipse开发工具已经不陌生了,那么Eclipse作为java主流的开发工具,是否能够开发PHP项目呢?答案如你所想,肯定是可以的!以下就是该IDE下如何配置 ...
- 11gR2 Agent 简介
目的:本文会对oracle 11gR2 集群件(Grid Infrastructure,以下简称GI) 新特性 agent进行介绍,包括 agent的功能,常见的agent介绍,以及基本的诊断方法. ...
- CCCC 以及 hihocoder offer收割赛11 ~~~
CCCC 真的很蒙 ,没有队服,没有狗牌,服务器崩溃到14:10 才开始比赛...(黑人问号 开始前,发现旁边是西交老大吴航,mad~各种紧张.看着大佬疯狂的敲宏定义就很怕啊.100多行,一行头 ...
- 无旋Treap【模板】P3369
题目 详情见链接. 代码 #include<cstdio> #include<iostream> #define outd(x) printf("%d\n" ...
- 使用EventLog组件保存Windows系统日志
实现效果: 知识运用: EventLog类的CreateEventSource方法 //用于建立一个应用程序 使用指定的Sourc作为向本机上的日志中写入日志项的有效事件源 CreateEventS ...
- smooth_L1_loss_layer.cu解读 caffe源码初认识
.cpp是cpu上运行的代码,.cu是gpu上运行的代码. 这是smooth_L1_loss_layer.cu的前向传播部分 #include "caffe/fast_rcnn_layers ...
- Hbase 完全分布式 高可用 集群搭建
1.准备 Hadoop 版本:2.7.7 ZooKeeper 版本:3.4.14 Hbase 版本:2.0.5 四台主机: s0, s1, s2, s3 搭建目标如下: HMaster:s0,s1(备 ...
- 【转】JavaScript 节点操作 以及DOMDocument属性和方法
最近发现DOMDocument对象很重要,还有XMLHTTP也很重要 注意大小写一定不能弄错. 属性: 1Attributes 存储节点的属性列表(只读) 2childNodes 存储节点的子节点列表 ...
- UI Testing in Xcode 7
参考文章: UI Testing in Xcode - WWDC 2015https://developer.apple.com/videos/play/wwdc2015-406/ Document ...
- comboBox 下拉宽度自适应
///适用combobox绑定datatable private void comboBox_DataSourceChanged(object sender, EventArgs e) { Combo ...