欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Python之JSON库中序列化和反序列化常用方法

程序员文章站 2022-04-11 10:57:30
...

1、为什么需要序列化与反序列化

我们知道,当两个进程进行网络通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等, 而这些数据都会以二进制序列的形式在网络上传送。不能直接传输Python对象。

那么当两个进程进行通信时,能否实现进程间的对象传送呢?答案是可以的!如何做到呢?这就需要序列化与反序列化了!

换句话说,一方面,发送方需要把这个Python对象转换为字节序列,然后在网络上传送,这就是序列化;另一方面,接收方需要从字节序列中恢复为Python对象,这就是反序列化。

当我们明晰了为什么需要序列化和反序列化后,我们很自然地会想序列化的好处。其好处一是实现了数据的持久化,通过序列化才可以把数据永久地保存到硬盘上(通常存放在文件里),二是,利用序列化实现远程通信,即在网络上传送对象的字节序列。

总的来说可以归结为以下几点:

(1)永久性保存对象,保存对象的字节序列到本地文件或者数据库中;
(2)通过序列化以字节流的形式使对象在网络中进行传递和接收;
(3)通过序列化在进程间传递对象;
———————
序列化(serialization):数据转换成二进制的有序的过程,把内存中数据保存到文件中。文件是一个字节序列,所以必须把数据转换成字节序列,输出到文件。这就是序列化

反序列化(deserialization):将有序的二进制序列转换成某种对象(字典,列表等)称为反序列化。例如将文件的一个个字节恢复成内存中对象。

持久化:序列化保存到文件就是持久化,序列
相关标签: python