Django:(08)序列化器
1、序列化和反序列化
变量从内存中变成可存储或传输的过程称之为序列化,序列化之后,就可以把序列化后的内容写入磁盘,或者通过网络传输到别的机器上。
反过来,把变量内容从序列化的对象重新读到内存里称之为反序列化。
序列化是将对象状态转换为可保持或可传输的形式的过程。序列化的补集是反序列化,后者将流转换为对象。这两个过程一起保证数据易于存储和传输。
2、Django中序列化器的定义和使用
定义:两种方法定义序列化器(serializer/ModelSerializer)
class CartSKUSerializer(serializers.ModelSerializer):
"""
购物车商品数据序列化器
"""
count = serializers.IntegerField(label='数量') class Meta:
model = SKU
fields = ('id', 'name', 'default_image_url', 'price', 'count')
使用:
查询模型类
实例一个序列化器,传入模型类对象
获取序列化后的结果(data属性)
query_set = Department.objects.all()
serializer = DepartmentSerializer(query_set, many=True)# 传入对象集时需指定many=True
serializer.data
3、Django中反序列化的参数校验
基本校验:
序列化器的创建: 通过data传入字典数据:
Serializer(instance=None, data=empty, **kwarg)
通过is_valid方法校验参数合法性
errors属性: 获取校验出错信息,字典类型。
validated_data属性: 校验通过得到的对象,类型为OrderedDict
通过 validators选项校验
在序列化器字段中添加validators选项参数进行校验
定义函数:
def validate_name(value):
# 校验部门名称
if not re.match('^[\u4e00-\u9fa5]+$', value):
raise ValidationError('部门名称只能为中文')
return value
在字段参数中添加选项:validators=[validate_name]
name = serializers.CharField(validators=[validate_name])
validate_<field>:对<field_name>字段进行验证
class DepartmentSerializer(serializers.Serializer):
"""部门数据序列化器"""
...
def validate_name(self, value):
# 校验部门名称
if not re.match('^[\u4e00-\u9fa5]+$', value):
raise ValidationError('部门名称只能为中文')
return value
validate:同时对多个字段进行比较验证
# 模型: users/models.py
class User(models.Model):
password = models.CharField(max_length=30) # 序列化器: users/serializer.py
class UserSerializer(serializers.Serializer): password = serializers.CharField(max_length=30, write_only=True)
password2 = serializers.CharField(max_length=30, write_only=True) def validate(self, attrs):
# 校验两次输入的密码是否正确
password = attrs['password']
password2 = attrs['password2']
if password != password2:
raise serializers.ValidationError('两次输入的密码不一样')
return attrs
3、Django中反序列化保存和修改数据
Serializer
类的三个方法save()
方法: 保存数据create()
方法: 新增数据update()
方法: 修改数据
新增或修改数据
Serializer(instance=None, data=empty)
新增:创建序列化器时,没有传递了
instance
参数my_dict = {'name': '研发部xx', 'create_date': '2018-1-1'}
s = DepartmentSerializer(data=my_dict)
s.save() # 新增修改:创建序列化器时,传递了
instance
参数department = Department.objects.get(id=1)
my_dict = {'name': '研发部xx', 'create_date': '2018-1-1'}
s = DepartmentSerializer(instance=department, data=my_dict)
s.save() # 修改部分修改:
partial=True
参数- 当修改数据时,序列化器默认要求传递所有
required=True
的字段,否则is_valid
验证不通过 可以通过设置
partial=True
允许只修改部分字段,如下:
- 当修改数据时,序列化器默认要求传递所有
s = DepartmentSerializer(department, data={'create_date': '2017-1-1'}, partial=True)
4、模型类序列化器
定义
model 指明参照哪个模型类
fields 指定序列化器中的属性有哪些 (可以是模型类中的字段,也可以模型类中没有的但需要校验的属性,比如类似:短信验证码,确认密码)
class DepartmentSerializer2(serializers.ModelSerializer):
class Meta:
model = Department
fields = '__all__' # 包含模型类中所有的字段
指定序列化器中包含哪些字段:fields = ('id', 'name')
排除掉模型类中指定的字段:exclude = ('is_delete',)
指明只读字段
read_only_fields = ('id', 'create_date')
仅用于序列化输出,在反序列化时不会进行校验和修改
指定 关联属性的序列化方式
Django:(08)序列化器的更多相关文章
- 怎样快速高效的定义Django的序列化器
1.使用Serializer方法自己创建一个序列化器 先写一个简单的例子 class BookInfoSerializer(serializers.Serializer): ""& ...
- Django REST framework 中的序列化器
在此之前定义一个序列化工具: views中的的代码 from rest_framework.viewsets import ModelViewSet from .models import B ...
- 写写Django中DRF框架概述以及序列化器对象serializer的构造方法以及使用
写写Django中DRF框架概述以及序列化器对象serializer的构造方法以及使用 一.了解什么是DRF DRF: Django REST framework Django REST framew ...
- Django REST Framework的序列化器是什么?
# 转载请留言联系 用Django开发RESTful风格的API存在着很多重复的步骤.详细可见:https://www.cnblogs.com/chichung/p/9933861.html 过程往往 ...
- Django REST Framework序列化器
Django序列化和json模块的序列化 从数据库中取出数据后,虽然不能直接将queryset和model对象以及datetime类型序列化,但都可以将其转化成可以序列化的类型,再序列化. 功能需求都 ...
- Django 学习之Django Rest Framework_序列化器_Serializer
作用: 1.序列化,序列化器会把模型对象转换成字典,经过response以后变成json字符串. 2.反序列化,把客户端发送过来的数据,经过request以后变成字典,序列化器可以把字典转成模型. 3 ...
- ajax发送json格式与文件数据、django自带的序列化器(了解)
上期内容回顾 聚合查询和分组查询 # 聚合查询 max min sum avg count # 查询关键字:aggregate from django.db.models import Max, Mi ...
- Django:RestFramework之-------序列化器
8.序列化 功能: 对请求数据进行验证 对Queryset进行序列化 8.1一个简单序列化: import json from api import models from rest_framewor ...
- 序列化器:ModelSerializer
ModelSerializer 类提供了一个快捷方式,可让你基于 Models 自动创建一个 Serializer 类,其中的字段与模型类字段对应. ModelSerializer 类与常规 Seri ...
随机推荐
- javaweb的maven项目结构
本来准备看javaweb的项目结构,因为之前自己建maven的项目结构,总是各种出错,后来干脆用maven自己携带的项目结构. 一个最基本的web目录结构如下,红框部分为必须有的,其他的随意. 这是一 ...
- Spring框架集成FreeMarker
一.Spring in Action (转自:http://blog.163.com/zhang-_-jie/blog/static/16178437820105821120822/ ) FreeMa ...
- 关于c语言中结构体的初始化
1.先定义结构体类型后再定义结构体变量: 格式为:struct 结构体名 变量名列表: struct book s1,s2,*ss://注意这种之前要先定义结构体类型后再定义变量: 2.在定义结构体类 ...
- 再论i++ ++i
#include <stdio.h> int main(void) { char acData[5] ={'A','B','C','D','E'}; char *pcData = NULL ...
- 洛谷P1169 棋盘制作【悬线法】【区间dp】
题目:https://www.luogu.org/problemnew/show/P1169 题意:n*m的黑白格子,找到面积最大的黑白相间的正方形和矩形. 思路:传说中的悬线法!用下面这张图说明一下 ...
- System.Web.HttpRequestValidationException: 从客户端(name="<a href=''>我是晓菜鸟</a>")中检测到有潜在危险的 Request.Form 值
这是一个比较常见的问题了,如果Web表单中有输入类似于 Html 标签之类的文本,在通过 Request.QueryString 或者 Request.Form 传递这些值的时候,就会触发这样的异常, ...
- 11、组件注册-使用FactoryBean注册组件
11.组件注册-使用FactoryBean注册组件 package org.springframework.beans.factory; import org.springframework.lang ...
- docker的网络服务
docker提供 网络服务,主要通过两种方式: 1.外部访问 2.容器互联 通过外部访问Docker容器,主要通过端口映射的方式. [root@docker ~]# docker run -t -P ...
- 009_Linux驱动之_request_irq()函数
1. request_irq()函数原型 int request_irq(unsigned int irq, irq_handler_t handler, unsigned long irqflags ...
- sql server 复习笔记2
主键约束 可以通过定义primary key 约束来定义主键, 用于强制表的实体化完整性,一个表只能有一个主键约束, 并且primary key 约束中的列不能为空值,由于primary key 约束 ...