zoukankan      html  css  js  c++  java
  • Django:序列化的几种方法

    前言

    关于序列化操作,就是将一个可迭代的数据结构,通过便利的方式进行我们所需要的操作。

    今天历来归纳一下,Django中的几种不同得分方法,已经Django-restframework提供的方法

    创建一个Django的项目

    再新建一个app

    创建一个模型,以书本出版社为例,自行迁移完成以后,再配置路由,主要讲解的是views.py,其他的不多说了。

    复制代码
    # RESFUL_DJ/app/models.py

    from django.db import models # Create your models here. class Publisher(models.Model): name = models.CharField(max_length=32, verbose_name='名称', unique=True) address = models.CharField(max_length=128, verbose_name='地址') def __str__(self): return self.name class Meta: db_table = 'db_publisher' verbose_name = "出版商" verbose_name_plural = verbose_name
    复制代码

    数据库中的内容(使用的是sqlite3)

    现在我们来展示数据库中的所有数据,以json的格式传给前端

    RESTFUL_DJ/app/views.py

    方法一:

    复制代码
    from django.http import HttpResponse
    
    from app import models
    
    def publisher_list(request):
        '''
        通过不同的方法,展示所有的出版社对象
        :param request: 请求
        :return: 出版社对象
        '''
        queryset = models.Publisher.objects.all()
    
        # 方法一
        data = []
        # 这个方法的缺点就是:
        # 如果字段多了的话,就需要一个一个去写,会很麻烦
        # 返回的是字典类型,所以需要json转换成json格式字符串
        for i in queryset:
            p_tmp = {
                "name": i.name,
                "address": i.address
            }
            data.append(p_tmp)
    
        import json
        return HttpResponse(json.dumps(data), content_type='application/json')
    复制代码

    结果:

    这是谷歌浏览器安装的插件的原因,方便查看,原结构是这样:

    方法二:

    复制代码
    from django.http import HttpResponse
    
    from app import models
    
    def publisher_list(request):
        '''
        通过不同的方法,展示所有的出版社对象
        :param request: 请求
        :return: 出版社对象
        '''
        queryset = models.Publisher.objects.all()
    
        # 方法二
        data = []
        # django自带的模型转字典方法
        # 缺点就是图片之类的文件无法转换
        # 返回的是字典类型,所以需要json转换成json格式字符串
        from django.forms.models import model_to_dict
        for i in queryset:
            data.append(model_to_dict(i))
    
        import json
        return HttpResponse(json.dumps(data), content_type='application/json')
    复制代码

     结果:

    方法三:

    复制代码
    from django.http import HttpResponse
    
    from app import models
    
    def publisher_list(request):
        '''
        通过不同的方法,展示所有的出版社对象
        :param request: 请求
        :return: 出版社对象
        '''
        queryset = models.Publisher.objects.all()
    
        # 方法三
        # 导入django自带的序列化器
        # # 返回的是json字符串,不需要再用json转换一次了
        from django.core import serializers
        data = serializers.serialize('json', queryset)
        return HttpResponse(data, content_type='application/json')
    复制代码

    结果:

    方法四:

    首先需要安装djangorestframework(pip install djangorestframework)

    配置好settings.py文件

    在app下新建文件serializers.py,(使用跟form差不多)

    复制代码
    from rest_framework import serializers
    from app import models
    
    class PublisherSerializer(serializers.Serializer): # 类的命名必须是models中的模型名称加Seriaizer
        id = serializers.IntegerField(read_only=True)
        name = serializers.CharField(max_length=32)
        address = serializers.CharField(max_length=128)
    
        def create(self, validated_data):
            '''
            重写create方法,创建数据
            :param validated_data: 用户传递的,经过了校验的数据
            :return: 创建的数据
            '''
            return models.Publisher.objects.create(**validated_data)
    
        def update(self, instance, validated_data):
            '''
            更新数据操作
            :param instance: 原来的数据
            :param validated_data: 用户传递的,经过了校验的数据
            :return: 更新后的数据
            '''
            instance.name = validated_data.get('name', instance.name)
            instance.address = validated_data.get('address', instance.address)
            instance.save()
            return instance
    复制代码

     在shell中,测试一下展示操作

    测试一下create共功能:

    运行项目,结果:

    复制代码
    from django.shortcuts import render
    from django.http import HttpResponse
    
    from app import models
    
    def publisher_list(request):
        '''
        通过不同的方法,展示所有的出版社对象
        :param request: 请求
        :return: 出版社对象
        '''
        queryset = models.Publisher.objects.all()
    
        # 方法四
        # 使用djangorestframework中的序列化
        from app import serializers
        serializer = serializers.PublisherSerializer(queryset, many=True) # 多个遍历
        data = serializer.data # OrderedDict对象
        import json
        return HttpResponse(json.dumps(data), content_type='application/json')
    复制代码


    在前面创建的serializers.py文件中定义的序列化字段,其实和models中的模型字段是一样的,我们可以继承过来使用

    继承serializers.ModelSerializer方法,里面本身就封装好了新建更新等数据操作的方法

    更改serializers.py文件的内容:

    复制代码
    from rest_framework import serializers
    from app import models
    
    
    class PublisherSerializer(serializers.ModelSerializer):
        class Meta:
            model = models.Publisher
            fields = (
                'id',
                'name',
                'address'
            )
    复制代码

     结果:

  • 相关阅读:
    imp.load_source的用法
    第12周翻译
    第十周学习笔记
    翻译:高级t
    t-sql
    9周学习笔记
    第8周学习笔记
    t-sql的楼梯:超越基本级别6:使用案例表达式和IIF函数
    数据库设计层次3:构建表
    第七周学习笔记
  • 原文地址:https://www.cnblogs.com/gcgc/p/11320636.html
Copyright © 2011-2022 走看看