day18 json与pickle

一、序列化

目的:将数据从内存中变成可以存储或者传输的过程

原因:程序在执行时就是在处理一系列状态的变化,这一系列“状态”在编程语言中会以各种数据结构存储在内存当中,而内存无法永久保存数据,断电或者重启时,内存中关于该段时间内的数据会全部消失;所以,为了将内存中的数据永久的保存到文件中,就需要将内存中的数据经过序列化处理,以便直接写入文件中。

优点:1.可以永久的保存数据的状态

          2.跨平台的数据交互能力更好

二、json 与pickle

1.json实例

字典序列化

import json
dic={"name":""Luffy,"age":18}
print(type(dic))   #<class "dict">
# 经过json 序列化之后变成了字符串格式
j=json.dumps(dic)
print(type(j))    #<class "str">
dic={"name":"Namy","age":18}
f=open("序列化对象""w")
f.write(j)  # == json.dump(dic,f)
f.close

#----反序列化----#
import json
f=open("序列化对象")
msg=json.loads(f.read())   #==  msg=json.load(f)

列表序列化

list=["how","old","are","you"]
j=json.dumps(list)
print(type(j))

2.pickle

序列化

import pickle
dic={"sunday":"sun","sweet":"cake"}
j=pickle.dumps(dic)  #将字典格式化成 "bytes"

反序列化

import pickle
f=open("序列化对象_pickle","rb")
msg=pickle.loads(f.read())   #== msg=pickle.load(f)

 

posted @ 2018-06-20 23:41  Smart1san  阅读(133)  评论(0编辑  收藏  举报