Json

JSON是一个序列化模块,一种用于存储和交换数据的语法。

JSON是用JavaScript对象表示法(JavaScript object notation)格式编写的文本。

可以将python数据类型 --—> json数据类型 --—>字符串 --—> 文件中

其他语言要想用python的数据

文件中 -–—> 字符串 -–—> json 数据格式 -–—> 其他语言的数据类型

在json中,所有的字符串都是双引号

元组比较特殊,若转成json数据,内部会将元组变成列表

set是不能换号json数据

json.dumps 序列化(编码),将对象编码成json对象

import json
import json
d = {
    'name':'zcy',
    'age':18,
}
a = json.dumps(d)
print(a)
{"name": "zcy", "age": 18}

json.loads 反序列化(解码),该函数返回python字典的数据类型

b = json.loads(a)
print(b)
{'name': 'zcy', 'age': 18}

json.dump不需要使用write()方法, 只需要写哪个字典、哪个文件即可;而.dumps()需要使用.write()方法写入

保存json数据时,用.json作文文件的后缀名

with open('user.json','w',encoding='utf-8') as f:
    json.dump(数据,句柄f)

json.load传的是文件对象,而loads传的是字符串; 使用loads时需要先读文件在使用,load则不用先读

with open('user.json','r',encoding='utf-8')
data = json.load(f)
print(data)

当将Python对象转换为JSON时,Python对象将被转换为对应JSON (JavaScript)类型:

Python JSON
dict Object
list Array
tuple Array
str String
int Number
float Number
True true
False false
None null

pickle

pickle是一个python自带的序列化模块

优点:可以支持python中所有的数据类型

​ 可以直接存'bytes'类型 的数据,pickle存取速度更快

缺点:只能支持python使用,不能跨平台

默认情况下,pickle数据格式使用相对紧凑的二进制表示。如果您需要最佳尺寸特征,则可以有效地压缩数据。

要序列化对象层次结构,只需调用该dumps()函数即可。同样,要对数据流进行反序列化,请调用该loads()函数

 posted on 2019-11-18 15:03  Rannie`  阅读(129)  评论(0编辑  收藏  举报
去除动画
找回动画