python序列化与反序列

python序列化与反序列

在python中提供了两个模块可进行序列化。分别是pickle和json。他们两者的功能都差不多,dumps和dump都是进行序列化,而loads和load则是反序列化。

模块1:pickle

pickle是python中独有的序列化模块。有个特别的名字,为泡菜。用于实现Python数据类型与Python特定二进制格式之间的转换。

1. .dumps()和.loads()为格式处理函数

import pickle

#序列化 d
= dict(name='Bob', age=20, score=88) c = pickle.dumps(d) #dumps将所传入的变量的值序列化为一个bytes, 就可以将这个bytes写入磁盘或者进行传输。 print(c)
#反序列化
c1
= pickle.loads(c) #把bytes loads为python对象 print((c1))

运行结果:

 

2..dump()和.load()主要用来读写json文件函数

import pickle
#
f = open('2.txt','wb')
d = dict(name='Bob', age=20, score=88)
pickle.dump(d,f)             #以二进制文件写入2.txt中
print(d)
f.close()

#
f1 = open('2.txt','rb')
r = pickle.load(f1)         #读出文件内容
print(r)

这里就不上图了。

模块2:json

大部分编程语言都会提供处理json数据的接口,用于实现Python数据类型与通用(json(其他编程语言))字符串之间的转换

直接上源码

1.json.dumps()和json.loads()是json格式处理函数

import json
#序列化
d = dict(name='Bob', age=20, score=88)
d1 = json.dumps(d)          #dumps方法是把pyhon对象转化为json对象  (转为字符串)
print(type(d1))
print(d1)
#反序列化
d2 = json.loads(d1)         #loads方法是把json对象转化为python对象     (字符串转为python对象)
print(type(d2))
print(d2)

运行结果: 

 

2.json.dump()和json.load()主要用来读写json文件函数

import json

#写操作
json_info = "{'name': 'Bob', 'age': 20, 'score': 88}"       #字符串  也可以是上面代码的d2变量
file = open('1.json','w',encoding='utf-8')                  #创建(打开)一个可写的1.json文件
json.dump(json_info,file)                   #将json信息写入文件中

#读操作
file = open('1.json','r',encoding='utf-8')
info = json.load(file)                  #读取json信息
print(info)

这里我就不上图了  都差不多的

总结:

pickle与json都可以实现序列化以及反序列化,它们之间不同的有以下几点:

1)、pickle不是用于多种语言间的数据传输,它仅作为python对象的持久化,只针对python的数据类型;而json可以支持更多语言的序列化和反序列化,在python中序列化一个自定义的类对象时,会抛出一个 TypeError。
2)、json的序列化输出是文本对象是str类型,而pickle序列化的输出是二进制字节-bytes。
3)、json可读性优于pickle。

 

posted @ 2019-03-09 12:33  cmap  阅读(315)  评论(0编辑  收藏  举报