美文网首页
python序列化与反序列化

python序列化与反序列化

作者: 戈羽殇雪 | 来源:发表于2019-11-11 11:37 被阅读0次

每种编程语言都有各自的数据类型,其中面向对象的编程语言还允许开发者自定义数据类型(如:自定义类),Python也是一样。很多时候我们会有这样的需求:

把内存中的各种数据类型的数据通过网络传送给其它机器或客户端;
把内存中的各种数据类型的数据保存到本地磁盘持久化;

如果要将一个系统内的数据通过网络传输给其它系统或客户端,我们通常都需要先把这些数据转化为字符串或字节串,而且需要规定一种统一的数据格式才能让数据接收端正确解析并理解这些数据的含义。XML 是早期被广泛使用的数据交换格式,在早期的系统集成论文中经常可以看到它的身影;如今大家使用更多的数据交换格式是JSON(JavaScript Object Notation),它是一种轻量级的数据交换格式。JSON相对于XML而言,更加加单、易于阅读和编写,同时也易于机器解析和生成。除此之外,我们也可以自定义内部使用的数据交换格式。

将对象转换为可通过网络传输或可以存储到本地磁盘的数据格式(如:XML、JSON或特定格式的字节串)的过程称为序列化;反之,则称为反序列化。

相关模块:
json:用于实现python数据类型与通用字符串之间的转换(json),提供的方法:dumps()、loads()、dump、load()
例如:保存一个人的信息:
序列化:

import json
info={
    'age':23,
    'name':'buffon'
}
with open('a.txt','w') as f:
    f.write(json.dumps(info))

dumps 是将python对象info转化成json字符串

反序列化:

import json
with open('a.txt','r') as f:
    data=f.read()
data1=json.loads(data)
print(data1)

而dump和load功能与dumps和loads类似,可以直接操作文件句柄,以load为例:

import json
with open('a.txt','r') as f:
    data1=json.load(f)
print(data1)

牵涉到的复杂数据的虚拟化,一般我们会用pickle模块,例如函数这种序列化使用json会报错
pickle模块实现了用于对Python对象结构进行 序列化 和 反序列化 的二进制协议,与json模块不同的是pickle模块序列化和反序列化的过程分别叫做 pickling 和 unpickling:

pickling: 是将Python对象转换为字节流的过程;
unpickling: 是将字节流二进制文件或字节对象转换回Python对象的过程;

  1. pickle模块与json模块对比
    JSON是一种文本序列化格式(它输出的是unicode文件,大多数时候会被编码为utf-8),而pickle是一个二进制序列化格式;
    JOSN是我们可以读懂的数据格式,而pickle是二进制格式,我们无法读懂;
    JSON是与特定的编程语言或系统无关的,且它在Python生态系统之外被广泛使用,而pickle使用的数据格式是特定于Python的;
    默认情况下,JSON只能表示Python内建数据类型,对于自定义数据类型需要一些额外的工作来完成;pickle可以直接表示大量的Python数据类型,包括自定数据类型(其中,许多是通过巧妙地使用Python内省功能自动实现的;复杂的情况可以通过实现specific object API来解决)

例如:

import pickle
def sayhi(name):
    print("hi,",name)
info={
    'age':23,
    'name':'buffon',
    'func':sayhi
}
with open('a.txt','wb') as f:
    f.write(pickle.dumps(info))

而反序列化时,需要将之前序列化的函数重新写入,否则在反序列化时会报错AttributeError: Can't get attribute 'sayhi' on...(在序列化时保存的内存的地址,反序列化时找不到当时的映射关系)
反序列化:

import pickle
def sayhi(name):
    print("hi,",name)

with open('a.txt','rb') as f:
    data=f.read()
data1=pickle.loads(data)
print(data1)

另外pickle模块的dump和load方法与json的功能基本类似

引用了部分文章:python序列化

相关文章

  • python序列化与反序列化

    json序列化与反序列化 序列化:dumps()/dump(),将python中字典类型的对象序列化后,转化成js...

  • 序列化和反序列细节处理

    python 中pickle 和 json 都是序列化和反序列化的模块。 关于序列化和反序列化 序列化和反序列化[...

  • 使用json模块

    json模块是python内置的用于序列化的模块。 序列化和反序列化 序列化就是将python类型的数据结构转换为...

  • python 实现list和dict的可序列化方案

    python原生的list与dict并不支持序列化,想要实现序列化,必须借助设计;python提供魔法方法gets...

  • Java序列化与反序列化

    问题 Java序列化与反序列化是什么?为什么需要序列化与反序列化?有什么好处?如何实现Java序列化与反序列化? ...

  • 序列化和反序列化的概念

    1序列化:把对象转为字节序列的过程 为序列化; 2相反:字节---------->对象 为反序列化 3 序列化的场...

  • Pickle 反序列化漏洞

    序列化与反序列化基础 我们知道各大语言都有其序列化数据的方式,Python当然也有,官方库里提供了一个叫做pick...

  • Python序列化pickle标准库

    听过Python序列化pickle标准库吗? 序列化 序列化 (Serialization)是将对象的状态信息转换...

  • Python 入门之 内置模块 -- 序列化模块(json模块、

    Python 入门之 内置模块 -- 序列化模块(json模块、pickle模块) 1、序列化 Python中这种...

  • DRF之序列化

    序列化 把Python中对象转换为json格式字符串 反序列化 把json格式转为为Python对象。 序列化两大...

网友评论

      本文标题:python序列化与反序列化

      本文链接:https://www.haomeiwen.com/subject/qxozbctx.html