序列化

  • 定义模型类
from django.db import models

# Create your models here.

class StuModel(models.Model):
SEX_CHOICES = (
(0, '女'),
(1, '男'),
) name = models.CharField(max_length=10)
sex = models.SmallIntegerField(choices=SEX_CHOICES, null=True)
group = models.ForeignKey('Group', on_delete=models.SET_NULL, null=True)
role = models.ManyToManyField('Roles') class Group(models.Model):
name = models.CharField(max_length=10) class Roles(models.Model):
name = models.CharField(max_length=10)
  • 视图函数
from django.shortcuts import render

# Create your views here.

from rest_framework import serializers
from rest_framework.views import APIView
from .models import *
from django.http import HttpResponse import json class MySerializer(serializers.Serializer):
name = serializers.CharField() # 普通查询
sex_field = serializers.IntegerField(source='sex') # 更改名称查询
sex = serializers.CharField(source='get_sex_display') # 内嵌chiose查询
group = serializers.CharField(source='group.name') # 关联查询
rol = serializers.SerializerMethodField() # manyToMany查询 def get_rol(self, row):
queryset = row.role.all()
resp = []
for item in queryset:
resp.append(
{
'id': item.id,
'name': item.name
},
)
return resp class MyView(APIView): def get(self, request):
queryset = StuModel.objects.all()
serializer = MySerializer(instance=queryset, many=True)
ret = json.dumps(serializer.data)
return HttpResponse(ret)
  • 自定义序列化对象

    • 自定义的序列化对象必须继承serializers.Serializer
    • 该序列化对象的字段名和类型要和所要系列化的对象的一样
      • 如果要自定义字段名,需要在类型里面加上source=数据库的字段名
      • 多对多查询需要将字段对用成SerializerMethodField的类实例

        -定义get_{field_name}的方法,在里面实现自定义的查询
    • 自定义序列化对象实例化时,将所要序列化对象的queryset对象赋值给instance属性,当queryset对象不止一个时,many=True
  • 模型序列化对象

class MySerializer(serializers.ModelSerializer):
# name = serializers.CharField() # 普通查询
# sex_field = serializers.IntegerField(source='sex') # 更改名称查询
# sex = serializers.CharField(source='get_sex_display') # 内嵌chiose查询
group = serializers.CharField(source='group.name') # 关联查询
rol = serializers.SerializerMethodField() # manyToMany查询 class Meta:
model = StuModel
fields = ['name', 'sex_field', 'sex', 'group', 'rol']
extra_kwargs = {
'sex_field': {'source': 'sex'},
'sex': {'source': 'get_sex_display'},
} def get_rol(self, row):
queryset = row.role.all()
resp = []
for item in queryset:
resp.append(
{
'id': item.id,
'name': item.name
},
)
return resp
  • 模型序列化需要继承ModelSerializer

  • 可以在extra_kwargs定制额外的属性,参考Serializer

  • 在Meta里面制定对应的模型和字段,但ModelSerializer只能实现简单的展示,复杂的展示还需要自己定制

  • depth:深度追踪

class MySerializer(serializers.ModelSerializer):

    class Meta:
model = StuModel fields = '__all__'
depth = 1 class MyView(APIView): def get(self, request):
queryset = StuModel.objects.all()
serializer = MySerializer(instance=queryset, many=True)
ret = json.dumps(serializer.data)
return HttpResponse(ret)

在Meta里面加上加上depth = 1,就可以去取它对应的关联表的的下一层的所有数据,depth为几就去找几层

rest_framework-序列化-1的更多相关文章

  1. django rest_framework 序列化组件详解

    为什么要用序列化组件 当我们做前后端分离的项目,我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 那么我们给前端数据的时候都要转成json格式,那就需要对我们从数据库拿到 ...

  2. rest_framework序列化组件

    一.Django自带的序列化组件  ==>对象序列化成json格式的字符串 from django.core import serializers from django.core import ...

  3. rest_framework序列化,反序列化

    序列化组件 from rest_framework.response import Response1.Response本质也是继承了httpresponse,比httpResponse还强大,传入一 ...

  4. rest_framework 序列化篇

    感谢alex和武沛齐老师 rest_framework中的序列化表示 from rest_framework import serializersclass RoleSerializer(serial ...

  5. rest_framework序列化

    1.序列化 1)拿到queryset 2)将queryset 给序列化类 serializer = IdcSerializer(idc)    #单个对象 serializer = IdcSerial ...

  6. 【Django】rest_framework 序列化自定义替换返回值

    # 序列化设置 class PagerSerialiser(serializers.ModelSerializer): name = serializers.CharField(source=&quo ...

  7. django rest_framework Serializers 序列化组件

    为什么要用序列化组件 当我们做前后端分离的项目~~我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 那么我们给前端数据的时候都要转成json格式,那就需要对我们从数据库拿 ...

  8. rest_framework之序列化组件

    什么是rest_framework序列化? 在写前后端不分离的项目时: 我们有form组件帮我们去做数据校验 我们有模板语法,从数据库取出的queryset对象不需要人为去转格式 当我们写前后端分离项 ...

  9. drf序列化组件

    rest_framework序列化之Serializer 步骤: 1.自定义一个类,继承Serializer类: 2.在类中写要序列化的字段: 3.使用:在views.py文件中,book_ser=B ...

  10. Serializers 序列化组件

    Serializers 序列化组件   为什么要用序列化组件 当我们做前后端分离的项目~~我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 那么我们给前端数据的时候都要转 ...

随机推荐

  1. MDI设置父子窗体

    1.新建父窗体,设置窗体属性:IsMdicontainer设置成true; 2.拖入button控件,修改button中的text. 3.点击button控件设置代码: //1.窗体实例化 Form ...

  2. DS博客作业02--栈和队列

    0.PTA得分截图 1.本周学习总结 1.1总结栈和队列内容 栈的存储结构及操作 栈的顺序存储结构 typedef struct { ElemType data[MaxSize]: int top: ...

  3. 选择tomcat时候提示Project facet Java version 1.8 is not supported.解决办法

    是因为jdk版本不一致导致的,如何解决? 方法一: 选中项目Properties,选择Project Facets,右击选择Java,Change Version 方法二: 在项目的目录下有一个.se ...

  4. org.apache.rocketmq.remoting.exception.RemotingTooMuchRequestException: sendDefaultImpl call timeout 和 RocketmqRemoting closeChannel: close the connection to remote address[] result: true

    org.apache.rocketmq.remoting.exception.RemotingTooMuchRequestException: sendDefaultImpl call timeout ...

  5. Journal of Proteome Research | An automated ‘cells-to-peptides’ sample preparation workflow for high-throughput, quantitative proteomic assays of microbes (解读人:陈浩)

    文献名:An automated ‘cells-to-peptides’ sample preparation workflow for high-throughput, quantitative p ...

  6. selenium3浏览器驱动设置

    设置浏览器驱动: 1.首先手动创建一个存放浏览器驱动的目录,如: C:\driver , 将下载的浏览器驱动文件(例如:chromedriver.geckodriver)丢到该目录下. 2.打开计算机 ...

  7. jupyter之配置自己喜欢的python环境

    之前安装anaconda,会自动安装jupyer笔记本,但是本人从来没有用过,近期查看github上的一些教程时,发现很多文件都是.ipynb为后缀的jupyter文件,于是自己准备琢磨一下把环境换成 ...

  8. VirtualBox 安装 Centos8 使用 Xshell 连接

    1.下载CentOS CentOS下载地址:https://wiki.centos.org/Download 这里选择本地安装包,网络安装包在安装时需要在线下载资源比较慢 2.安装VirtualBox ...

  9. Matplotlib 精简实例入门

    Matplotlob 简明实例入门 通过几个实例,快速了解matplotlib.pyplot 中最为常见的折线图,散点图,柱状图,直方图,饼图的用法 如果您需要更为详细的内容,请参考官方文档: htt ...

  10. Anaconda常用命令收藏----后期还会更新

    一.更换jupyter notobook的打开目录 一般载在安装好Anaconda的时候,打开jupyter指向的目录一般是系统的根目录,如C:\Users\25282,但是这样的话对C盘是个不小的负 ...