1. 什么是接口?

交换数据

http://openweathermap.org/current

  1. json简介

JSON 是存储和交换文本信息的语法。类似 XML

JSON 语法是 JavaScript 语法的子集

  1. Json语法规则

数据在名称、值对中

数据由逗号分隔

花括号保存对象

方括号保存数组

Json的值可以是:

数字(整数或浮点数)

字符串(在双括号中)

逻辑值(true或false)

数组(在方括号中)

对象(在花括号中)

Null

  1. 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)

  1. 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}]

  1. 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)

这里的缩进是每行都有的

  1. 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=(',',':')))

  1. 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时

  1. dumps()的作用,由于python只在自己的编译环境中有效,这里用dumps()把python的对象转换成服务器能够识别的字符串。
  1. 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

  1. 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]

  1. 将类对象转换成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"}

  1. 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操作了解的更多相关文章

  1. python中json操作

    1.写操作.json文件dumps().dump()函数 d = { 'zll': { 'addr': '北京', 'age': 28 }, 'ljj': { 'addr': '北京', 'age': ...

  2. Python中json的简单读写操作

    Python中json的简单读写操作 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的 ...

  3. Neo4j:图数据库GraphDB(四)Python中的操作

    本文总结下Python中如何操作Neo4j数据库,用到py2neo包,Pip install 一下. 1 连接neo4j数据库:跟其它数据库一样,操作前必须输入用户名和密码及地址连接一下. from ...

  4. python中json格式数据输出实现方式

    python中json格式数据输出实现方式 主要使用json模块,直接导入import json即可. 小例子如下: #coding=UTF-8 import json info={} info[&q ...

  5. python中文件操作的六种模式及对文件某一行进行修改的方法

    一.python中文件操作的六种模式分为:r,w,a,r+,w+,a+ r叫做只读模式,只可以读取,不可以写入 w叫做写入模式,只可以写入,不可以读取 a叫做追加写入模式,只可以在末尾追加内容,不可以 ...

  6. python中文件操作的其他方法

    前面介绍过Python中文件操作的一般方法,包括打开,写入,关闭.本文中介绍下python中关于文件操作的其他比较常用的一些方法. 首先创建一个文件poems: p=open('poems','r', ...

  7. python MySQLdb用法,python中cursor操作数据库(转)

    数据库连接 连接数据库前,请先确认以下事项: 您已经创建了数据库 TESTDB. 在TESTDB数据库中您已经创建了表 EMPLOYEE EMPLOYEE表字段为 FIRST_NAME, LAST_N ...

  8. (数据科学学习手札126)Python中JSON结构数据的高效增删改操作

    本文示例代码及文件已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 在上一期文章中我们一起学习了在Python ...

  9. python中json的操作示例

    先上一段示例 # -*- coding: cp936 -*- import json #构造一个示例数据,并打印成易读样式 j = {} j["userName"]="a ...

随机推荐

  1. JavaWeb_05_xml相关&dtd快速入门

    学东西怎么学,是什么,能做什么,怎么去做!! 1.xml的简介 1.eXtensible Markup Language:可扩展标记型语言 标记型语言:html是标记型语言 也是使用标签来操作 可扩展 ...

  2. ios 11 12以后下拉刷新不回位的解决方法

    原因:  iOS11弃用了automaticallyAdjustsScrollViewInsets属性,新增contentInsetAdjustmentBehavior来替代它 //解决方案 添加如下 ...

  3. (转)VC得到可用的串口列表

    //枚举串口 //参数:bEnablePort,哪个串口有效,bEnablePort[0]表示COM1,bEnablePort[n-1]表示COMn //返回值:有效的串口个数 int EnumAll ...

  4. HTML 中的特殊字符

    空格符         <小于号    < >大于号    > &和好      & ¥人民币  ¥ ©  版权   © ®  注册商标 ® ℃ 摄氏度  ° ...

  5. jsp另外五大内置对象之config

    //配置web.xml <?xml version="1.0" encoding="UTF-8"?><web-app xmlns:xsi=&q ...

  6. 【TensorFlow入门完全指南】神经网络篇·自动编码机

    自动编码机(Autoencoder)属于非监督学习,不需要对训练样本进行标记.自动编码机(Autoencoder)由三层网络组成,其中输入层神经元数量与输出层神经元数量相等,中间层神经元数量少于输入层 ...

  7. 关于火狐浏览器在ubuntu和安卓手机上的同步

    最近在ubuntu使用火狐浏览器,感觉还不错.我想着,如果在我的安卓手机上装一个火狐浏览器,我就可以在手机上查看电脑上所收藏的网站了.然后我就去安卓应用市场下载了最新版的火狐浏览器.令人奇怪的是,我在 ...

  8. 关于一些Spring MVC控制器的参数注解总结

    昨天同事问我控制器参数的注解的问题,我好久没那样写过,把参数和url一起设置,不过,今天我看了一些文章,查了一些资料,我尽可能的用我自己的理解方式来解释它吧! 1.@RequestParam绑定单个请 ...

  9. wxWidgets:处理wxEVT

    我们仍然以继承于wxFrame的MyFrame作为例子. MyFrame.h: class MyFrame : public wxFrame { ...... private: ...... void ...

  10. python_105_类的特殊成员方法

    aa.py class C(): def __init__(self): self.name='QiZhiguang' 类的特殊成员方法: # 1. __doc__ 表示类的描述信息 class Do ...