01_Tutorial 1: Serialization 序列化
1、序列化
1、官方教程
https://q1mi.github.io/Django-REST-framework-documentation/tutorial/1-serialization_zh/
https://www.django-rest-framework.org/tutorial/1-serialization/
2、序列化方式1:serializers.Serializer
# 序列化方式1:serializers.Serializer
# 序列化方式1:serializers.Serializer class SnippetSerializer1(serializers.Serializer):
"""序列化,正反"""
"""
序列化字段 GET请求
"""
id = serializers.IntegerField(read_only=True)
title = serializers.CharField(required=False, allow_blank=True, max_length=100) code = serializers.CharField(style={'base_template': 'textarea.html'})
# 多文本框的类型,比如XML,HTML,SHELL, python
# 在某些情况下如何显示,比如渲染HTML的时候
# {'base_template': 'textarea.html'}标志等同于在Django Form类中使用widget=widgets.Textarea linenos = serializers.BooleanField(required=True)
language = serializers.ChoiceField(choices=LANGUAGE_CHOICES, default='python')
style = serializers.ChoiceField(choices=STYLE_CHOICES, default='friendly') """
反序列化字段 POST,PUT请求
""" def create(self, validated_data):
"""
根据提供的验证过的数据,创建并返回一个新的snippet实例
"""
return Snippet.objects.create(**validated_data) # 保存到数据库 def update(self, instance, validated_data):
"""
根据提供的验证过的数据更新和返回一个已经存在的`Snippet`实例。
"""
instance.title = validated_data.get('title', instance.title) # 如果post该字段则取该字段,否则直接从instance中取
instance.code = validated_data.get('code', instance.code)
instance.linenos = validated_data.get('linenos', instance.linenos)
instance.language = validated_data.get('language', instance.language)
instance.style = validated_data.get('style', instance.style)
instance.save() # 保存到db
return instance
3、view视图
from django.test import TestCase # Create your tests here. from snippets.models import Snippet
from snippets.serializers import SnippetSerializer
from rest_framework.renderers import JSONRenderer
from rest_framework.parsers import JSONParser # ## 序列化 GET方法
def test1():
snippet = Snippet(code='foo = "bar"\n')
snippet.save() snippet = Snippet(code='print "hello world"\n') # 获取字段,其他的都default
snippet.save() # 保存到db
serializer = SnippetSerializer(snippet) # 序列化为一个class对象
serializer.data
# {'id': 2, 'title': '', 'code': 'print "hello world"\n', 'linenos': False, 'language': 'python', 'style': 'friendly'}
type(serializer.data) # 现在是什么类型呢? ReturnDict
# <class 'rest_framework.utils.serializer_helpers.ReturnDict'> content = JSONRenderer().render(serializer.data) # 转化为json, Python原生数据类型
# content
# b'{"id":2,"title":"","code":"print \\"hello world\\"\\n","linenos":false,"language":"python","style":"friendly"}'
type(content)
# <class 'bytes'> # ## 反序列化 POST PUT
def test2(content):
from django.utils.six import BytesIO # IO,内存的数据 stream = BytesIO(content) # 获取内存中的数据 # <_io.BytesIO object at 0x00000264CC1FE780>
data = JSONParser().parse(stream) # 解析为data,什么类型? 一个流(stream)解析为Python原生数据类型
type(data) # <class 'dict'> serializer = SnippetSerializer(data=data) # 序列化
serializer.is_valid() # 校验
# True
serializer.validated_data # 校验通过的数据
# OrderedDict([('title', ''), ('code', 'print "hello world"'),('linenos', False), ('language', 'python'), ('style', 'friendly')])
type(serializer.validated_data)
# <class 'collections.OrderedDict'> serializer.save() # 保存到db,什么类型? 将Python原生数据类型恢复成正常的对象实例
# <Snippet: Snippet object (3)>
总结
# ## 总结
'''
POST方法create
反序列化 Python原生数据类型 ---> 模型实例 1、json类型的数据,每个字段必须存在
b'{"id":2,"title":"","code":"print \\"hello world\\"\\n","linenos":false,"language":"python","style":"friendly"}' 2、解析成为dict字典,<class 'dict'> Python原生数据类型
data = JSONParser().parse(stream) 3、序列化,<class 'snippets.serializers.SnippetSerializer'>
serializer = SnippetSerializer(data=data) 4、是否校验通过
serializer.is_valid() 5、校验后的数据, <class 'collections.OrderedDict'>
serializer.validated_data 6、保存到DB,<Snippet: Snippet object (3)> 正常的对象实例
serializer.save() ''' '''
GET list方法总结
序列化 模型实例 ---> Python原生数据类型 1、接收每个字段,snippet = Snippet(code='foo = "bar"\n')
code='foo = "bar"\n', title='', style='friendly',language='python', linenos=False 2、保存到DB <class 'snippets.models.Snippet'>
snippet.save() 3、序列化,对象 模型实例
serializer = SnippetSerializer(snippet) 4、序列化的数据 # <class 'rest_framework.utils.serializer_helpers.ReturnDict'>
serializer.data 5、转换为json数据 <class 'bytes'> Python原生数据类型
content = JSONRenderer().render(serializer.data) '''
4、序列化方式2:推荐,serializers.ModelSerializers
# 序列化方式2:serializers.ModelSerializers (推荐)
"""
1、快捷方式
2、自动,确定一组字段
3、默认实现简单的create与update方法
# 序列化方式2:serializers.ModelSerializers (推荐)
"""
1、快捷方式
2、自动,确定一组字段
3、默认实现简单的create与update方法
"""
class SnippetSerializer(serializers.ModelSerializer):
class Meta:
model = Snippet
fields = ['id', 'title', 'code', 'linenos', 'language', 'style']
查看所有字段
# 通过打印,序列化器类实例的结构(representation),查看它的所有字段。
from snippets.serializers import SnippetSerializer
serializer = SnippetSerializer()
print(serializer)
print(repr(serializer)) # repr 规范string形式
# SnippetSerializer():
# id = IntegerField(label='ID', read_only=True)
# title = CharField(allow_blank=True, max_length=100, required=False)
# code = CharField(style={'base_template': 'textarea.html'})
# linenos = BooleanField(required=False)
# language = ChoiceField(choices=[('Clipper', 'FoxPro'), ('Cucumber', 'Gherkin'), ('RobotFramework', 'RobotFramework'), ('abap', 'ABAP'), ('ada', 'Ada')...
# style = ChoiceField(choices=[('autumn', 'autumn'), ('borland', 'borland'), ('bw', 'bw'), ('colorful', 'colorful')...
5、视图
from django.shortcuts import render # Create your views here. from django.http import HttpResponse
from django.views.decorators.csrf import csrf_exempt
from rest_framework.renderers import JSONRenderer # 渲染器
from rest_framework.parsers import JSONParser # 解析器 from snippets.models import Snippet
from snippets.serializers import SnippetSerializer class JSONResponse(HttpResponse):
"""
一个把content数据,渲染为json数据的HTTPResponse
An HttpResponse that renders its content into JSON.
"""
def __init__(self, data, **kwargs):
content = JSONRenderer().render(data)
kwargs['content_type'] = 'applications/json'
super(JSONResponse, self).__init__(content, **kwargs)
# def __init__(self, content_type=None, status=None, reason=None, charset=None): # 列出所有现有的snippet或创建一个新的snippet /snippet
@csrf_exempt # 从不具有CSRF令牌的客户端对此视图进行POST
def snippet_list(request):
"""
列出所有的code snippet,或创建1个新的snippet
"""
if request.method == 'GET':
snippet = Snippet.objects.all() # queryset对象实例
serializer = SnippetSerializer(snippet, many=True) # serializer模型实例
return JSONResponse(serializer.data) # 序列化的数据 ReturnDict ---> json elif request.method == 'POST':
data = JSONParser().parse(request) # python原生数据 ---> json
serializer = SnippetSerializer(data=data) # serializer模型实例
if serializer.is_valid(): # data验证
serializer.save() # 保存到db, 正常的对象实例
return JSONResponse(serializer.data, status=201) # 验证通过的data,ReturnDict ---> json
return JSONResponse(serializer.errors, status=400) # 未验证的通过的data, # 一个与单个snippet对象相应的视图 snippet/1
@csrf_exempt
def snippet_detail(request, pk):
"""
获取,更新,删除1个code snippet
"""
try:
snippet = Snippet.objects.get(pk=pk)
except Snippet.DoesNotExist:
return HttpResponse(status=404) if request.method == 'GET':
serializer = SnippetSerializer(snippet)
return JSONResponse(serializer.data) elif request.method == 'POST':
data = JSONParser().parse(request)
serializer = SnippetSerializer(snippet, data=data)
if serializer.is_valid():
serializer.save()
return JSONResponse(serializer.data)
return JSONResponse(serializer.errors, status=400) elif request.method == 'DELETE':
snippet.delete()
return HttpResponse(status=404)
6、效果
01_Tutorial 1: Serialization 序列化的更多相关文章
- JAVA Serialization 序列化
最近在做Android 项目时用到了WebView,可悲的是,在html上有无数用户的操作,而这些操作被JS返回给了Android的内存中,当深层的Activity开启时,之前的Activity很可能 ...
- Android Serialization序列化
Android Serialization 目的: 为了方便測试传感器数据处理算法,Android程序的採集数据.序列化保存为文件.pc程序再通过反序列化读入对象,在PC上測试算法. Java 序列化 ...
- JAVA-基础(六) Java.serialization 序列化
序 列 化 序列化(serialization)是把一个对象的状态写入一个字节流的过程. Serializable接口 只有一个实现Serializable接口的对象可以被序列化工具存储和恢复.Ser ...
- android precelable和Serialization序列化数据传输
一 序列化原因: 1.永久性保存对象,保存对象的字节序列到本地文件中:2.通过序列化对象在网络中传递对象:3.通过序列化在进程间传递对象. 二 至于选取哪种可参考下面的原则: 1.在使用内存的时候,P ...
- <经验杂谈>C#/.Net中xml的Serialization序列化与DeSerializetion反序列化
1.先讲概念:.Net Framework提供了对应的System.Xml.Seriazliation.XmlSerializer负责把对象序列化到XML,和从XML中反序列化为对象.Serializ ...
- django restframework 教程之Serialization(序列化)
介绍 本教程将会通过创建一个简单的粘贴代码项目,突出显示WebAPI,过程中,会介绍组成REST框架的各种组件,让你全面了解如何配合使用. 环境设置 建议使用virtualenv建立新的虚拟环境,确保 ...
- [.net 面向对象程序设计进阶] (12) 序列化(Serialization)(四) 快速掌握JSON的序列化和反序列化
[.net 面向对象程序设计进阶] (12) 序列化(Serialization)(四) 快速掌握JSON的序列化和反序列化 本节导读: 介绍JSON的结构,在JS中的使用.重点说明JSON如何在.N ...
- 最经常使用的两种C++序列化方案的使用心得(protobuf和boost serialization)
导读 1. 什么是序列化? 2. 为什么要序列化?优点在哪里? 3. C++对象序列化的四种方法 4. 最经常使用的两种序列化方案使用心得 正文 1. 什么是序列化? 程序猿在编写应用程序的时候往往须 ...
- 最常用的两种C++序列化方案的使用心得(protobuf和boost serialization)
导读 1. 什么是序列化? 2. 为什么要序列化?好处在哪里? 3. C++对象序列化的四种方法 4. 最常用的两种序列化方案使用心得 正文 1. 什么是序列化? 程序员在编写应用程序的时候往往需要将 ...
随机推荐
- Hystrix【异常机制处理】
在之前的老版本中,feign中是默认开启hystrix的,从新版本中默认已经关闭了,如果要通过FeignClient调用服务并开启hystrix的话,需要自定义开启,即:feign.hystrix.e ...
- C++ 计算定积分、不定积分、蒙特卡洛积分法
封装成了一个类,头文件和源文件如下: integral.h #pragma once //Microsoft Visual Studio 2015 Enterprise #include <io ...
- 小白入门.有函数F(x)=(x+1)^2和G(x)=2x+1.输入x值计算F(G(x))。
#include<stdio.h> #include<math.h> void main() { float x,y; printf("Please input x\ ...
- go http简单的表单处理
//表单处理 package main import ( "net/http" "io" "fmt" &qu ...
- Qt更新组件出现(“要继续此操作,至少需要一个有效且已启用的储存库”)
Qt更新组件出现(“要继续此操作,至少需要一个有效且已启用的储存库”) 目的: 当时在安装Qt时,有些组件暂时没用着,然后过一段时间后,需要用到某些该组件时,不用删掉重新再安装. 操作: Wind ...
- java 禁用科学计数法
禁用科学计数法 Double num = 80000000000.000001; System.out.println("默认计数法:num=" + num); NumberFor ...
- centos 7 配置pytorch运行环境
华为云服务器,4核心8G内存,没有显卡,性能算凑合,赶上双11才不到1000,性价比还可以,打算配置一套训练densenet的环境. 首先自带的python版本是2.7,由于明年开始就不再维护了,所以 ...
- 3_PHP表达式_1_常量
以下为学习孔祥盛主编的<PHP编程基础与实例教程>(第二版)所做的笔记. PHP常量分为自定义常量与预定义常量. 1.自定义常量 在使用前必须先定义,PHP的define()函数专门用于定 ...
- 如何导出robotframework的工程
不知道是不是只有我一个小白,自己折腾了很久,也百度了很久,不知道怎么导出哇.现在来扫扫盲罗.我拿自己的项目举例:找到我的RF工程目录可以看到下面有3个项目,直接拷贝你想要的项目就ok啦,是不是so e ...
- springboot下@webfilter的使用
启动类加了@ServletComponentScan,无论过滤器类加不加@Componment urlPatterns = {"/test/*"}都可以生效 单使用@Compone ...