详解Python中的序列化(简单易懂版)

1.什么是数据序列化?

序列化 (Serialization),是指把程序中的一个类转化成一个标准化的格式。标准化的意义是这个格式可以跨程序,跨平台的被使用,而且保持其原有的内容,规范。

2.为什么要进行数据序列化呢?

(1)一致性

我们将要保存的数据,序列化成标准的格式(Json格式或者Pickle格式)。之后再反序列化回来,数据依然是原来的。保持了数据的一致性。

(2)有效性

序列化之后,可以减少内存和网络资源的占用。

(3)兼容性

将数据序列化之后,Json格式或者Pickle格式,我可以在其他平台(其他操作系统的电脑)上依然使用。
我用python对数据进行了序列化,我之后可以使用java等其他语言,对其进行反序列,然后进行使用,数据并没有发生改变。

3.数据序列化的应用

(1)应用一

你的程序需要和其他程序交流,例如 平台 API, 网页请求
在这里插入图片描述

(2)应用二

串行任务流,每一个任务结束之后数据通过序列化传递到下一个任务。
在这里插入图片描述

4.JSON

JSON 是一个文件格式,也是一个标准化的数据传输方案,通常网站的后端和前端的交流,移动 APP 和云服务器的交流方式都是通过 JSON。

(1)序列化

# 导入json模块
import json

simple_dict = {'name': 'zxy', 'age': 21}
with open('simple_dict.txt', 'w') as file_to_write:
    # 进行json序列化,然后写入simple_dict.txt文件中
    json.dump(simple_dict, file_to_write)

(2)反序列化

with open('simple_dict.txt', 'r') as file_to_read:
    loaded_simple_dict = json.load(file_to_read)
    print(loaded_simple_dict)
    print(type(loaded_simple_dict))

在这里插入图片描述

(3)Json 方法的弊端

当遇到一些 Python 特定的高级数据类型的时候,Json 会因为没有标准而无法进行序列化。
会报如下错误:
在这里插入图片描述

5.Pickle

Pickle 和 Json 不同的是,Pickle 是 Python 专属的序列化方案,可以转化大多数 Python 的数据类型,并且储存方式是二进制(Byte Code)。二进制的储存方式只有机器才能理解,但是同时也保证了一定的数据隐秘性和高效性。

(1)序列化

import pickle
import datetime
abc_dict = {datetime.datetime(2019, 7, 18, 0, 0): 9682.24,
            datetime.datetime(2019, 7, 17, 0, 0): 9411.61,
            datetime.datetime(2019, 7, 16, 0, 0): 10858.7,
            datetime.datetime(2019, 7, 15, 0, 0): 10195.0,
            datetime.datetime(2019, 7, 14, 0, 0): 11378.23,
            datetime.datetime(2019, 7, 13, 0, 0): 11810.0,
            datetime.datetime(2019, 7, 12, 0, 0): 11338.9,
            datetime.datetime(2019, 7, 11, 0, 0): 12090.99,
            datetime.datetime(2019, 7, 10, 0, 0): 12577.85}

with open('abc.pk', 'wb') as file_to_write:
    pickle.dump(abc_dict, file_to_write)

二进制的储存方式只有机器才能理解,保证了一定的数据隐秘性和高效性。
在这里插入图片描述

(2)反序列化

import pickle
import datetime
abc_dict = {datetime.datetime(2019, 7, 18, 0, 0): 9682.24,
            datetime.datetime(2019, 7, 17, 0, 0): 9411.61,
            datetime.datetime(2019, 7, 16, 0, 0): 10858.7,
            datetime.datetime(2019, 7, 15, 0, 0): 10195.0,
            datetime.datetime(2019, 7, 14, 0, 0): 11378.23,
            datetime.datetime(2019, 7, 13, 0, 0): 11810.0,
            datetime.datetime(2019, 7, 12, 0, 0): 11338.9,
            datetime.datetime(2019, 7, 11, 0, 0): 12090.99,
            datetime.datetime(2019, 7, 10, 0, 0): 12577.85}

with open('abc.pk', 'wb') as file_to_write:
    # pickle序列化,然后以二进制的形式存入文件中
    pickle.dump(abc_dict, file_to_write)

with open('abc.pk', 'rb') as file_to_read:
    # 以二进制的形式进行读取文件
    abc_dict_pk = pickle.load(file_to_read)
    print(abc_dict_pk)
    print(type(abc_dict_pk))

在这里插入图片描述

6.总结

这里两个方法的行为都是在序列化数据,所以在调用函数上感觉完全一样。
但是本质上 Json 写入文件的是字符串,而 Pickle 则是把数据转化成了二进制,两个是完全不同的处理方案。

本文参考自:https://zhuanlan.zhihu.com/p/87470851

  • 7
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在 Django ,ModelSerializer 是 Django REST Framework 最常用的序列化器之一。它是一个自动化序列化组件,可以帮助我们快速地将一个 Django 模型转换成一个 RESTful API 的响应格式。 具体来说,ModelSerializer 将一个 Django 模型转换成一个 JSON 格式的响应,同时也可以将一个 JSON 格式的请求转换成 Django 模型。这使得我们能够很方便地将 Django 模型与 RESTful API 集成起来。 使用 ModelSerializer 需要进行如下步骤: 1. 创建一个继承自 ModelSerializer 的序列化器类。 2. 在序列化器类指定模型类和需要序列化的字段。 3. 在视图函数使用序列化器类进行序列化。 下面是一个示例代码: ```python from rest_framework import serializers from myapp.models import MyModel class MyModelSerializer(serializers.ModelSerializer): class Meta: model = MyModel fields = '__all__' ``` 上述代码,我们首先导入了 serializers 模块和 MyModel 模型类。然后,我们创建了一个名为 MyModelSerializer 的序列化器类,它继承自 ModelSerializer。在序列化器类的 Meta 类,我们指定了模型类为 MyModel,并且将 fields 属性设置为 '__all__',表示序列化所有字段。 接下来,在视图函数使用 MyModelSerializer 进行序列化: ```python from rest_framework import generics from myapp.serializers import MyModelSerializer from myapp.models import MyModel class MyModelList(generics.ListCreateAPIView): queryset = MyModel.objects.all() serializer_class = MyModelSerializer ``` 上述代码,我们首先导入了 generics 模块、MyModelSerializer 序列化器类和 MyModel 模型类。然后,我们创建了一个名为 MyModelList 的视图类,它继承自 generics.ListCreateAPIView。在视图类,我们指定了查询集为 MyModel.objects.all(),序列化器类为 MyModelSerializer。 以上就是 ModelSerializer 的基本使用方法。通过 ModelSerializer,我们可以很方便地将一个 Django 模型转换成一个 RESTful API 的响应格式,使得我们能够更加方便地构建 Web 应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值