如果我们要在不同的编程语言之间传递对象,就必须把对象序列化为标准格式,比如XML,但更好的方法是序列化为JSON,因为JSON表示出来就是一个字符串,可以被所有语言读取,也可以方便地存储到磁盘或者通过网络传输。JSON不仅是标准格式,并且比XML更快,而且可以直接在Web页面中读取,非常方便。
对json和pinkle的简单认识与区别
- 我们内存中的数据对象,字典列表它们不能直接存在文件里,文件它只能存bytes类型或者字符串类型,那么如果我们想把字典列表存到文件里面,就需要把它变成字符串或者bytes类型,然后当我们要用到他们的时候,在把他们转为Python的数据类型。我们的Json就是用来干这个事的
- 那么json解决了什么问题呢,(哈哈,那就多了),它解决了不同的语言,不同的平台之间的数据交换,这样使Python和Java之间的数据进行交换了,比如我是做运维的。我想调我们公司开发人员的一些系统,但是这些一般是Java开发的,我们不会,那我就可以让他给我开个接口,说你给我返回个json类型就行了,所以不管对方是什么语言写的,
- pinkle是Python特有的,它的优点是它可以支持Python的所有数据类型,json的话他不支持类,一个Python的日期格式它都支持不了
- 两个的用法是一样的。
- 但是使用pinkle必须先转为bytes类型
- 记得老老实实的dumps和loads多次,因为Python里面好像只能loads一次
- 即使可以dumps多次loads多次也尽量不要这样搞,因为loads多了,自己都不知道是第几层了,这样得到的就不是我们想要的数据类
- 既然这么麻烦,可以使用
Shelve
模块,这样我想dumps多少次它不会乱,新挖掘的一个模块,之前一直都不知道有这个模块
json与pinkle
shelve模块
shelve模块是一个通过key-value的形式进行数据的持久化的模块
import shelve
d = shelve.open('shelve_test') #打开一个文件
class Test(object):
def __init__(self,n):
self.n = n
t = Test(123)
t2 = Test(123334)
name = ["alex","rain","test"]
d["test"] = name #持久化列表
d["t1"] = t #持久化类
d["t2"] = t2
d.close()
那么怎么把数据读出来
d = shelve.open('shelve_test') #打开一个文件
print(d.get("t1"))
print(d.items())