序列化

  • 定义模型类
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. go入门二

    一.流程控制 1.选择结构 if-else: package main import ( "io/ioutil" "fmt" ) func main(){ co ...

  2. java-方法。(新手)

    import java.util.ArrayList; //导入包.import java.util.Iterator;import java.util.LinkedList;import java. ...

  3. Fiddler4 手机抓包

    1.要对计算机Fiddler进行配置,允许远程计算机连接. 2.保证手机电脑在同一局域网中. 3.手机上设置代理服务器.以华为手机为例,设置-->WLAN-->找到并长按目前所连接的WiF ...

  4. Integration of Metabolomics and Transcriptomics To Reveal Metabolic Characteristics and Key Targets Associated with Cisplatin Resistance in Nonsmall Cell Lung Cancer(解读人:林山云)

    期刊名:J. Proteome Res 发表时间:(2019年8月) IF:3.78 单位: 上海第九人民医院药学系,上海交通大学药学院 上海交通大学药物与生物化学系   物种:人源A549细胞系 技 ...

  5. 动态规划/MinMax-Predict the Winner

    2018-04-22 19:19:47 问题描述: Given an array of scores that are non-negative integers. Player 1 picks on ...

  6. 【分布式锁】06-Zookeeper实现分布式锁:可重入锁源码分析

    前言 前面已经讲解了Redis的客户端Redission是怎么实现分布式锁的,大多都深入到源码级别. 在分布式系统中,常见的分布式锁实现方案还有Zookeeper,接下来会深入研究Zookeeper是 ...

  7. OpenCV-Python BRIEF(二进制的鲁棒独立基本特征) | 四十二

    目标 在本章中,我们将看到BRIEF算法的基础知识 理论 我们知道SIFT使用128维矢量作为描述符.由于它使用浮点数,因此基本上需要512个字节.同样,SURF最少也需要256个字节(用于64像素) ...

  8. Hive学习笔记六

    目录 查询 一.基本查询 1.全表和特定列查询 2.列别名 3.算术运算符 4.常用函数 5.Limit语句 二.Where语句 1.比较运算符(Between/In/ Is Null) 2.Like ...

  9. coding++:JS/jQuery获取兄弟姐妹等元素

    jQuery获取: jQuery.parent(expr),找父亲节点,可以传入expr进行过滤,比如$("span").parent()或者$("span") ...

  10. iOS 页面流畅技巧(2)

    一.屏幕显示图像的原理 首先从过去的 CRT 显示器原理说起.CRT 的电子枪按照上面方式,从上到下一行行扫描,扫描完成后显示器就呈现一帧画面,随后电子枪回到初始位置继续下一次扫描.为了把显示器的显示 ...