rest-framework之序列化组件
一:django自带序列化组件
Django内置的serializers(把对象序列化成json字符串)
from django.core import serializers
def test(request):
book_list = models.Book.objects.all()
ret = serializers.serialize('json', book_list)
return HttpResponse(ret)
二: rest-framework序列化之Serializer
Serializer各种方法即单表查询
from django.db import models # Create your models here. class Book(models.Model):
nid = models.AutoField(primary_key=True)
name = models.CharField(max_length=32)
price = models.DecimalField(max_digits=5, decimal_places=2)
publish_date = models.DateField() publish = models.ForeignKey(to='Publish',to_field='nid',on_delete=models.CASCADE)
authors=models.ManyToManyField(to='Author')
def __str__(self):
return self.name class Author(models.Model):
nid = models.AutoField(primary_key=True)
name = models.CharField(max_length=32)
age = models.IntegerField()
author_detail = models.OneToOneField(to='AuthorDatail',to_field='nid',unique=True,on_delete=models.CASCADE) class AuthorDatail(models.Model):
nid = models.AutoField(primary_key=True)
telephone = models.BigIntegerField()
birthday = models.DateField()
addr = models.CharField(max_length=64) class Publish(models.Model):
nid = models.AutoField(primary_key=True)
name = models.CharField(max_length=32)
city = models.CharField(max_length=32)
email = models.EmailField()
def __str__(self):
return self.name
def test(self):
return self.email
models.py
在app01中创建一个新的py文件,mySer.py
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from rest_framework import serializers class BookSerializer(serializers.Serializer):
# 重命名
thisname = serializers.CharField(source='name')
price = serializers.CharField()
# 在source不光能指定字段的名字,还能指定函数的名字
test = serializers.CharField(source='publish.test') # 在source后这样写,能拿到表中的任意字段
# publish = serializers.CharField(source='publish.city')
# source加.内容,判断点后面的是一个字段还是一个可执行的函数,
# 是函数就加括号执行,是字段,取出对应的值给publish # SerializerMethodField可以制定一个方法
publish = serializers.SerializerMethodField()
#方法名:叫get_字段名,要传参数,参数是:当前book对象
def get_publish(self, obj):
dic = {'name': obj.publish.name,'email':obj.publish.email}
return dic
mySer.py
详解如下

来到视图对象
from django.shortcuts import render, HttpResponse
from rest_framework.views import APIView
from app01 import models
from app01.mySer import BookSerializer
from django.http import JsonResponse # Create your views here. # Django内置的serializers(把对象序列化成json字符串)
# from django.core import serializers
# def test(request):
# book_list = models.Book.objects.all()
# ret = serializers.serialize('json', book_list)
# return HttpResponse(ret) class Books(APIView):
def get(self, request, *args, **kwargs):
ret = models.Book.objects.all() # queryset对象
# 生成一个序列化对象,传参数
# 序列化多条,记住many=True
book_ser = BookSerializer(ret, many=True) return JsonResponse(book_ser.data, safe=False)
views.py

总结以上内容
-1 重命名:用source:xx = serializers.CharField(source='name')
-2 取出出版社名字:
方式一:
-在模型表中重写__str__方法
-publish=serializers.CharField()
方式二:
-用source
-拿出出版社的城市
-publish=serializers.CharField(source='publish.city') *****如果不指定source,字段必须对应起来,如果指定了source,字段可以任意命名
-source 可以指定字段,也可也指定方法
publish.test这是个方法,会执行该方法,并拿到返回结果
test = serializers.CharField(source='publish.test')
-3 SerializerMethodField,可以指定一个方法
publish=serializers.SerializerMethodField()
# 方法名:叫get_字段名,要传参数,参数是:当前book对象
def get_publish(self,obj):
# obj 是当前book对象
dic={'name':obj.publish.name,'email':obj.publish.email}
return dic
-方法内部可以继续用其他的序列化类
-ModelSerializer
-必须在类中写
class Meta:
model=指定表
# fields = '__all__'
# 指定只取这两个字段
fields = ['nid','name']
# 去掉指定的字段
# exclude=['publish','authors']
# fields,跟exclude不能连用
# 指定深度,就是跨几个表(官方建议小于10,我给你的建议小于3)
# depth = 2
Serializer小总结
Serializer序列化的跨表查询

在postman中的运行效果

效果不好的话将代码复制到www.json.cn中,可以折叠,看起来更清晰,即

如果不想写for循环,还有一种方法
在mySer中写上
# 作者的序列化的类
class AuthorSerializer(serializers.Serializer):
nid = serializers.CharField()
name = serializers.CharField()
age = serializers.CharField()
在图书序列化的类下面 写方法
# 通过上面的作者的序列化的类来实现
def get_authors(self, obj):
auths = obj.authors.all()
#可以继续用序列化来处理
auth_ser=AuthorSerializer(auths,many=True)
return auth_ser.data
这样,在视图函数中一样能拿到图书的作者们
三:serializers.ModelSerializer序列化方法
第一种方式(类中类)
在mySer.py中
from app01.models import Book
class BookSerializer(serializers.ModelSerializer):
# 不用按字段,直接序列化到表模型
#必须写一个内部内,名字必须交Meta
class Meta:
model=Book
fields='__all__' #闹出book表的所有字段
postman运行结果会出现这样,publish和authors都是id

那么在

#重写属性
publish=serializers.CharField(source='publish.name')

在mySer中写
authors=serializers.SerializerMethodField()
def get_authors(self,book):
auths=book.authors.all()
auth_ser=AuthorSerializer(auths,many=True)
return auths.data

第二种方式:depth=? 深度(跨表查询,可控性查,效率低)



ModelSerializer
-必须在类中写
class Meta:
model=指定表
# fields = '__all__'
# 指定只取这两个字段
fields = ['nid','name']
# 去掉指定的字段
# exclude=['publish','authors']
# fields,跟exclude不能连用
# 指定深度,就是跨几个表(官方建议小于10,我给你的建议小于3)
# depth = 2
rest-framework之序列化组件的更多相关文章
- restful framework之序列化组件
一.Django自带序列化组件 from django.core import serializers def test(request): book_list = Book.objects.all( ...
- Rest Framework:序列化组件
Django内置的serializers(把对象序列化成json字符串 from django.core import serializers def test(request): book_list ...
- [Django REST framework - 序列化组件、source、钩子函数]
[Django REST framework - 序列化组件.source.钩子函数] 序列化器-Serializer 什么是rest_framework序列化? 在写前后端不分离的项目时: 我们有f ...
- Restful framework【第三篇】序列化组件
基本使用 -序列化 -对象,转成json格式 用drf的序列化组件 -定义一个类继承class BookSerializer(serializers.Serializer): -写字段,如果不指定so ...
- 基于Django的Rest Framework框架的序列化组件
本文目录 一 Django自带序列化组件 二 rest-framework序列化之Serializer 三 rest-framework序列化之ModelSerializer 四 生成hypermed ...
- django rest framework 序列化组件总结
序列化组件总结 一. 序列化组件本质上为了实现前后端分离,而进行json序列化的一个组件形式,极大方便了解析数据的作用 二. 所有序列化是基于APIView 解析器实现的,通过内部的多继承关系方便实现 ...
- cvb源码分析,resful规范,drf,drf序列化组件,95
1 CBV的源码分析 -Class Base View(基于类的视图) -Function Base View(基于函数的视图) -def as_view 类方法 -def view:类方法内部,闭包 ...
- drf 之序列化组件
序列化 把Python中对象转换为json格式字符串 反序列化 把json格式转为为Python对象. 用orm查回来的数据都是都是一个一个的对象, 但是前端要的是json格式字符串. 序列化两大功能 ...
- Django Rest framework 之 序列化
RESTful 规范 django rest framework 之 认证(一) django rest framework 之 权限(二) django rest framework 之 节流(三) ...
- rest-framework框架——APIView和序列化组件
一.快速实例 Quickstart http://www.cnblogs.com/yuanchenqi/articles/8719520.html restful协议 ---- 一切皆是资源,操作只是 ...
随机推荐
- 从ROS bag文件中提取图像
从ROS bag文件中提取图像 创建launch文件,如下: export.launch <launch> <node pkg="rosbag" type=&qu ...
- 数据科学:Pandas 和 Series 的 describe() 方法
一.Pandas 和 Series 的 describe() 方法 1)功能 功能:对数据中每一列数进行统计分析:(以“列”为单位进行统计分析) 默认只先对“number”的列进行统计分析: 一列数据 ...
- 安装appium需要注意的事项
参考 虫师 的博客园 :http://www.cnblogs.com/fnng/p/4560298.html 1.其中第二篇中,打开命令行用的不是windows中的cmd打开的界面,而是用node. ...
- Java中的阻塞和非阻塞IO包各自的优劣思考(经典)
Java中的阻塞和非阻塞IO包各自的优劣思考 NIO 设计背后的基石:反应器模式,用于事件多路分离和分派的体系结构模式. 反应器(Reactor):用于事件多路分离和分派的体系结构模式 通常的,对一个 ...
- Rest之路 - Rest架构中的重要概念(二)
状态无关性 Rest 架构中不维持client,resource and request 的状态,我们通常称 Rest 服务是状态无关的.基于此的优势是为设计Rest架构提供了简便:每一个请求可以被完 ...
- Lagom production deployment
tutorial:https://developer.lightbend.com/guides/lagom-kubernetes-k8s-deploy-microservices/ 一.harbor ...
- select,poll,epoll,selectors
一 了解select,poll,epoll IO复用:为了解释这个名词,首先来理解下复用这个概念,复用也就是共用的意思,这样理解还是有些抽象, 为此,咱们来理解下复用在通信领域的使用,在通信领域中为了 ...
- python--open用法
open/文件操作f=open('/tmp/hello','w') #open(路径+文件名,读写模式) #读写模式:r只读,r+读写,w新建(会覆盖原有文件),a追加,b二进制文件.常用模式 如:' ...
- 图灵机器人,web录音实现自动化交互问答
一.图灵机器人 介绍 图灵机器人 是以语义技术为核心驱动力的人工智能公司,致力于“让机器理解世界”,产品服务包括机器人开放平台.机器人OS和场景方案. 官方地址为: http://www.tuling ...
- 黑客工具包ShadowBrokers浅析
臭名昭著的方程式组织工具包再次被公开,TheShadowBrokers 在 steemit.com博客上提供了相关消息. 本次被公开的工具包大小为117.9MB,包含23 个黑客工具,其中部分文件显示 ...