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'
        )

  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
假设我们有一个Django模型如下: ```python from django.db import models class Book(models.Model): title = models.CharField(max_length=200) author = models.CharField(max_length=200) publication_date = models.DateField() price = models.DecimalField(max_digits=6, decimal_places=2) ``` 我们可以使用Django内置的序列化工具将其序列化为JSON格式的数据。首先,我们需要在视图中导入`JsonResponse`和`serializers`: ```python from django.http import JsonResponse from django.core import serializers ``` 然后,我们可以在视图函数中查询所有的书籍,并将其序列化为JSON字符串: ```python def book_list(request): books = Book.objects.all() data = serializers.serialize('json', books) return JsonResponse(data, safe=False) ``` 在这里,`serializers.serialize`函数将查询结果序列化为JSON格式的数据,并将其存储为`data`变量。我们将其传递给`JsonResponse`构造函数,它将其转换为JSON响应并返回。 我们还可以使用Django REST框架的序列化器来实现相同的功能。我们需要首先定义一个序列化器类来指定我们要序列化的模型及其字段: ```python from rest_framework import serializers class BookSerializer(serializers.ModelSerializer): class Meta: model = Book fields = ('id', 'title', 'author', 'publication_date', 'price') ``` 接下来,我们可以在视图中使用这个序列化器来序列化我们的数据: ```python from rest_framework.decorators import api_view from rest_framework.response import Response @api_view(['GET']) def book_list(request): books = Book.objects.all() serializer = BookSerializer(books, many=True) return Response(serializer.data) ``` 在这里,我们使用`@api_view`装饰器来定义一个基于函数的视图。我们查询所有的书籍并将其传递给`BookSerializer`构造函数。`many=True`参数告诉序列化器我们要序列化多个对象。最后,我们将序列化后的数据作为响应返回。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值