Python序列化

序列化

pickle

在程序运行的过程中,所有的变量都是在内存中,比如定义一个dict

dict1 = {name:"lili",age:18}

在这里我把name进行修改,改成”leilei“,但是一旦程序结束,变量所占用的内存就会被操作系统全部回收,如果没有把修改的name存到磁盘上,下次name初始化的时候又是”lili“

在这里我们把变量从内存中变成可存储或者传输的过程称之为序列化,在 python 中叫 picking,序列化之后,我们就可以把序列化后的内容写入磁盘,或是通过网络传输到别的机器上。反之,把变量内容从序列化的对象重新读取到内存里称之为反序列化,即unpicking。

python提供了pickle模块来实现序列化。

import pickle
d = dict({name:"lili",age:18})
#pickle.dumps()方法把任意对象序列化成一个bytes,然后就可以把bytes写入文件
print(pickle.dumps(d))

#把序列化后的对象写入文件
f = open("dump.txt",'wb')
#参数一:要写入的对象, 参数二:写入文件的对象
pickle.dumps(d,f)
f.close()

#从文件中读取序列化后的对象
f2 = open("dump.txt","rb")
#pickle.load()反序列化对象
d = pickle.load(f)
f.close()

注意:pickle只能用于python,并且不同版本的python彼此都不兼容,因此,只能用pickle保存一些不重要的数据,这样即使不能成功的反序列化也没什么关系。

练习:

import pickle

# dict1 = {"1":23,"3":3344}
class Student():                    #定义Student类
    def __init__(self,name,age):    #初始化name和age属性
        self.name = name
        self.age = age

    def __str__(self):              #重写 str 方法,将类中name和age 输出格式转为  "小明"-20
        return "%s-%d"%(self.name,self.age)

stu = Student("小明",20)


with open("ceshi.txt","wb") as f:     #将内存中的 Student类 序列化,存入ceshi.txt文件中
#     # f.write(pickle.dumps(stu))      #pickle.dumps是将任意对象序列化为二进制文件
    pickle.dump(stu,f)                  #pickle.dump是将任意对象序列化为二进制字符串,写入打开的f文件中

with open("ceshi.txt","rb") as f:   #将ceshi.txt文件中的序列化内容 反序列化,返回内存中的类输出
    # res = pickle.loads(f.read())    #f.read是二进制字符串,也就是序列化的内容
    # print(res)
    # print(type(res))
    res = pickle.load(f)
    print(res)

Json

如果我们需要在不同的编程语言之间传递对象,那么我们必须把对象序列化成标准化格式,比如xml,但是更好的方法是json,因为json表现出来就是一个字符串,可以被所有的语言读取,也方便存储到磁盘或者网络传输,json不仅是标准模式,并且速度也比xml更快,还可以在web中读取,非常方便。

JSON类型Python类型
{} 对象dict
[] 数组list
“string”str
1234.56int或float
true/falseTrue/False
nullNone

语法:

import json

json.dumps(obj)  
功能:将obj序列化为json字符串

json.loads(jsonstr)
功能:将json字符串,反序列化为python的基本数据类型

json.dump(obj,f,default=func)
obj:被序列化的对象
f:打开的文件
default:将对象转为字典的函数

json.load(f,object_hook=func)
参数一:打开的文件
参数二:将字典转为对象的函数

注意:json字符中key都是使用""括起来的.

把python的dict对象变成一个json

import json

d = dict({name:"lili",age:19})
#使用json.dumps()方法返回一个str,这个str就是标准的json
print(json.dumps(d))

#把json反序列化为一个python对象
jsonStr = '{name:"lili",age:19}'
print(json.loads(jsonStr))

将一个class对象序列化为json

import json

class Student(object):
    def __init__(self, name, age, score):
        self.name = name
        self.age = age
        self.score = score
        
#将student对象转换为dict        
def student2dict(std):
    return {
        'name': std.name,
        'age': std.age,
        'score': std.score
    }        
s = Student('Bob', 20, 88)
#参数一:要传入的对象  参数二:将对象转为dict的函数
json.dumps(s,default=student2dict)

#将dict转为对象
def dict2student(d):
    return Strdent(d['name'],d['age'],d['score'])
jsonStr ='{"age": 20, "score": 88, "name": "Bob"}'
#json反序列化为一个对象
#参数一:json字符串,参数二:dict转为对象的函数
print(json.loads(jsonStr,object_hook=dict2student))

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值