什么叫序列化——将原本的字典、列表等内容转换成一个字符串的过程就叫做序列化

序列化的目的

1、以某种存储形式使自定义对象持久化
2、将对象从一个地方传递到另一个地方。
3、使程序更具维护性。

json 是一种通用的序列化格式,只有很少的数据类型可以通过json转化为字符串

import json
dic = {'k1':'q1','k2':'q2','k3':'q3'}
str_dic = json.dumps(dic)  # 序列化,将一个字典转换成一个字符串
print(type(str_dic),str_dic)  # 注意,json转换完的字符串类型的字典中的字符串是由""表示的
dic1 = json.loads(str_dic)  # 反序列化,将字符串转回字典
print(type(dic1),dic1)  # 注意,要用json的loads功能处理的字符串类型的字典中的字符串必须由""表示
list1 = [1,2,3,4,{'k1':'q1','k2':'q2','k3':'q3'}]
str_list1 = json.dumps(list1)  # 注意,可以处理嵌套的数据类型
print(type(str_list1),str_list1)
list1_1 = json.loads(str_list1)
print(type(list1_1),list1_1)
import json
dic = {'k1':'q1','k2':'q2','k3':'q3'}
with open('qqq','w',encoding='utf-8') as f:  # dump方法接受一个文件句柄(f),将内容转换成json字符串写进文件
    json.dump(dic,f)
with open('qqq','r',encoding='utf-8') as f:  # load方法接受一个文件句柄(f),将文件中json字符串的内容转换成数据结构返回
    dic_1 = json.load(f)
    print(dic_1)
Skipkeys:默认值是False,如果dict的keys内的数据不是python的基本类型(str,unicode,int,long,float,bool,None),
      设置为False时,就会报TypeError的错误。此时设置成True,则会跳过这类key ensure_ascii:,当它为True的时候,所有非ASCII码字符显示为\uXXXX序列,只需在dump时将ensure_ascii设置为False即可,
      此时存入json的中文即可正常显示。) indent:应该是一个非负的整型,如果是0就是顶格分行显示,如果为空就是一行最紧凑显示,若为其它数值,则是每行缩进的字符数 separators:分隔符,实际上是(item_separator, dict_separator)的一个元组,默认的就是(‘,’,’:’);
      这表示dictionary内keys之间用“,”隔开,而KEY和value之间用“:”隔开。 sort_keys:将数据根据keys的值进行排序
import json
data = {'username':['哈哈','收到'],'sex':'male','age':26}
json_dic2 = json.dumps(data,sort_keys=True,indent=2,separators=(',',':'),ensure_ascii=False)
print(json_dic2)

pickle  python中所有的数据类型都可转化成字符串,但反序列化内容只能使用python读取

     且反序列化依赖代码

import pickle
dic = {'q1':'w1','q2':'w2','q3':'w3'}
str_dic = pickle.dumps(dic)
print(str_dic)  #一串二进制内容

dic2 = pickle.loads(str_dic)
print(dic2)    #字典

import time
struct_time  = time.localtime(1000000000)
print(struct_time)
f = open('pickle_file','wb')
pickle.dump(struct_time,f)
f.close()

f = open('pickle_file','rb')
struct_time2 = pickle.load(f)
f.close()
print(struct_time2.tm_year)

shelve 只有一个方法,open(),拿到一个文件句柄,操作与字典类似

import shelve
f = shelve.open('aaa')
f['s']={1:'a',2:'b'}
f.close()
f1 = shelve.open('aaa')
s = f1['s']  # 直接调用key,若不存在会报
f1.close()
print(s,s2)

 

posted on 2019-05-15 17:29  幸福的小耗子  阅读(156)  评论(0编辑  收藏  举报