day 94 RestFramework序列化组件与视图view
一 、复习
1. CBV流程
class BookView(View): def get():
pass
def post():
pass #url(r'^books/', views.BookView.as_view()),
#url(r'^books/', View.as_view()),
#url(r'^books/', View.view),
一旦用户访问books:
View.view(request)==View.dispatch(request)==self.get(request)
2.Restframework下的APIView流程
class BookView(APIView(View)): def get():
pass
def post():
pass #url(r'^books/', views.BookView.as_view()),
#url(r'^books/', APIView.as_view()),
#url(r'^books/', View.view), 一旦用户访问books: View.view(request)==APIView.dispatch(request)====self.get(request) 3 新的request对象 def APIView.dispatch(request):
request = self.initialize_request(request, *args, **kwargs)
request._request.GET
request._request.POST
request.POST
request.GET
request.data(针对post请求,put/patch)
3.序列化组件
from rest_framework import serializers class BookSerializers(serializers.Serializer):
title=serializers.CharField(max_length=)
price=serializers.DecimalField(max_digits=,decimal_places=)
publish=serializers.CharField(max_length=,source="publish.name")
#authors=serializers.CharField(max_length=,source="authors.all")
authors=serializers.SerializerMethodField()
def get_authors(self,obj):
temp=[]
for obj in obj.authors.all():
temp.append(obj.name)
return temp '''
bs=BookSerializers(book_list,many=True)
temp=[]
for obj in book_list: temp.append({
'title':obj.title,
'price':obj.price,
'publish':obj.publish.name,
'authors':
}) bs.data=json.dumps(temp) ''' class BookView(APIView): def get(self,request): book_list=Book.objects.all()
bs=BookSerializers(book_list,many=True) # [{},{},{}]
bs1=BookSerializers(model_obj) # {} return Response(bs1.data) def post(self, request): print("request.data",request.data)
print("request.data",request.data["title"])
print("request.POST",request.POST) return HttpResponse("post.....")
二 、 RestFramwork之序列化组件1(get请求) .
from django.shortcuts import render,HttpResponse,redirect # Create your views here.
from django.views import View
from app01.models import Book
import json from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework import serializers """
有了modelSerializer后以下的代码都没用啦 。
from rest_framework import serializers class BookSerializers(serializers.Serializer):
title =serializers.CharField(max_length=32)
price =serializers.DecimalField(max_digits=8,decimal_places=2)
publish =serializers.CharField(max_length=32,source="publish.Email")
# authors =serializers.CharField(max_length=32,source="authors.all")
authors =serializers.SerializerMethodField()
def get_authors(self,obj):
temp =[]
for obj in obj.authors.all():
temp.append(obj.name)
return temp """ """
#总结的源码
bs =BookSerializers(book_list,many=True)
temp=[]
for obj in book_list:
temp.append({
’titlte':obj.title,
’price':obj.price,
’publish':obj.publish.name,
'authors':obj.authors. })
#总结的源码 bs.data =json.dumps(temp)
""" from rest_framework.serializers import ModelSerializer
class BookModelSerializers(ModelSerializer):
class Meta:
model =Book
fileds ="__all__"
authors =serializers.SerializerMethodField()
def get_authors(self,obj):
temp =[]
for obj in obj.authors.all():
temp.append(obj.name)
return temp class BookView(APIView):
"""
get请求:获取所有的书籍
post请求:添加一本书籍
"""
def get(self,request):
book_list =Book.objects.all()
bs =BookModelSerializers(book_list,many= True) return Response(bs.data) """
def get(self,request):
print(request._request.GET)
print(request.GET)
print(request.query_params) book_list= Book.objects.all()
# 方式一:
temp=[]
from django.forms.models import model_to_dict
# for book in book_list:
# temp.append(model_to_dict(book)) #序列化方式一 django提供的. #方式二:
# from django.core.serializers import serialize
# data =serialize("json",book_list) #序列化方式二 django提供的.
# return Response(data) #方式三:
bs =BookSerializers(book_list,many=True)
print("bs:is",bs) return Response(bs.data)
""" class BookDetailView(View):
pass
以上代码有问题打印不出来 publish 和author字段的内容.
三、RestFramwork之序列化组件2(POST请求 添加数据).
查看红颜色部分为post请求
from rest_framework.serializers import ModelSerializer
class BookModelSerializers(ModelSerializer):
class Meta:
model =Book
fields ="__all__"
authors =serializers.SerializerMethodField()
def get_authors(self,row):
temp =[]
for i in row.authors.all():
print(i.name)
temp.append({'id':i.id,'name':i.name})
return temp
class BookView(APIView):
"""
get请求:获取所有的书籍
post请求:添加一本书籍
"""
def get(self,request):
book_list =Book.objects.all()
bs =BookModelSerializers(instance=book_list,many= True)
print(bs.data)
return Response(bs.data)
def post(self,request):
bs =BookModelSerializers(data=request.data)
if bs.is_valid(): #校验字段接口
obj =bs.save() #创建记录接口create
return Response(bs.data) #序列化接口
return Response(bs.error)#序列化接口
三、RestFramwork之序列化组件3(GET请求 查询某一本书籍数据).
views文件
class BookDetailView(APIView):
"""
查询某一本书籍
"""
def get(self,request,id):
book =Book.objects.filter(pk=id).first()
print(id)
bs = BookModelSerializers(book)
print("bs.dataaaaa",bs.data)
return Response(bs.data)
url
from django.conf.urls import url
from django.contrib import admin from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^books/$',views.BookView.as_view()),
url(r"^books/(\d+)/$",views.BookDetailView.as_view())
注意$符号必须加上,否则会出错
]
三、RestFramwork之序列化组件4(PUT请求 修改某一本书籍数据).
class BookDetailView(APIView):
"""
查询某一本书籍
"""
def get(self,request,id):
book =Book.objects.filter(pk=id).first()
print(id)
bs = BookModelSerializers(book)
print("bs.dataaaaa",bs.data)
return Response(bs.data) """
修改某一本书籍
"""
def put(self,request,id):
book =Book.objects.filter(pk=id).first()
print(request.data) bs = BookModelSerializers(data=request.data,instance=book)
if bs.is_valid():
bs.save()# book.update(request.data) return Response(bs.data) else:
return Response(bs.errors)
四、RestFramwork之序列化组件5(delete请求 删除某一本书籍数据).
class BookView(APIView):
"""
get请求:获取所有的书籍
post请求:添加一本书籍
"""
def get(self,request):
book_list =Book.objects.all()
bs =BookModelSerializers(instance=book_list,many= True)
return Response(bs.data)
def post(self,request):
bs =BookModelSerializers(data=request.data)
if bs.is_valid(): #校验字段接口
obj =bs.save() #创建记录接口create
return Response(bs.data) #序列化接口
return Response(bs.error)#序列化接口 class BookDetailView(APIView):
"""
查询某一本书籍
"""
def get(self,request,id):
book =Book.objects.filter(pk=id).first()
print(id)
bs = BookModelSerializers(book)
print("bs.dataaaaa",bs.data)
return Response(bs.data) """
修改某一本书籍
"""
def put(self,request,id):
book =Book.objects.filter(pk=id).first()
print(request.data) bs = BookModelSerializers(data=request.data,instance=book)
if bs.is_valid():
bs.save()# book.update(request.data) return Response(bs.data) else:
return Response(bs.errors) """
删除某一本书籍
"""
def delete(self,request,id):
Book.objects.filter(pk=id).first().delete()
return Response()
from app01.models import Publish,Author
class PublishModelSerializers(ModelSerializer):
class Meta:
model =Publish
fields ="__all__" class PublishView(APIView):
"""
publishs : get请求 :获取所有的出版社
post请求:获取一个出版社
"""
def get(self,request): #查询所有数据
publish_list =Publish.objects.all()
bs =PublishModelSerializers(publish_list,many=True)
return Response(bs.data)#序列化接口 def post(self,request): #添加一条数据
bs =PublishModelSerializers(data=request.data)
if bs.is_valid():#校验字段接口
obj=bs.save()#创建记录接口create return Response(bs.data)#序列化接口 return Response(bs.errors)#序列化接口 class PublishDetailView(APIView):
def get(self,request,id): #查询一条数据
publish =Publish.objects.filter(pk=id).first()
bs =PublishModelSerializers(publish)
return Response(bs.data)
def put(self,request,id): #修改一条数据
publish =Publish.objects.filter(pk=id).first()
bs =PublishModelSerializers(data=request.data,instance=publish)
if bs.is_valid():
bs.save()# publish.update(request.data)
return Response(bs.data)
else:
return Response(bs.errors) def delete(self,request,id): #删除一条数据
Publish.objects.filter(pk=id).delete()
return Response()
(序列化结束)
五、RestFramwork之视图
视图函数进行封装 ,book 模型序列化,publish模型序列化 。。。。可以给他们进行封装所以引出了视图混合类(maxins)。
第一种封装 maxin 混合类
url文件 (红色部分)
from django.conf.urls import url
from django.contrib import admin from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^books/$', views.BookView.as_view()),
url(r"^books/(\d+)/$", views.BookDetailView.as_view()), #mixin增删改查方式使用的
url(r"^publishes/$", views.PublishView.as_view()),
url(r'^publishes/(\d+)/$', views.PublishDetailView.as_view()), url(r'^authors/$', views.AuthorsModelView.as_view({"get": "list", "post": "create"}), ),
url(r'^authors/(?P<pk>\d+)/$', views.AuthorsModelView.as_view({
'get': 'retrieve',
'put': 'update',
'delete': 'destroy'
}), ),
view文件
#通过mixins的第一种方式 查询增删改查#######################mixins################################# from rest_framework import generics
from rest_framework import mixins class PublishModelSerializers(ModelSerializer):
class Meta:
model = Publish
fields = "__all__" class PublishView(mixins.ListModelMixin,
mixins.CreateModelMixin,
generics.GenericAPIView):
queryset=Publish.objects.all()
serializer_class =PublishModelSerializers
def get(self,request,*args,**kwargs):
return self.list(self,request,*args,**kwargs) def post(self,request,*args,**kwargs):
return self.create(request,*args,**kwargs) class PublishDetailView(mixins.UpdateModelMixin,
mixins.RetrieveModelMixin,
mixins.DestroyModelMixin,
generics.GenericAPIView):
queryset = Publish.objects.all()
serializer_class = PublishModelSerializers def get(self, request, *args, **kwargs):
return self.retrieve(self, request, *args, **kwargs) def put(self, request, *args, **kwargs):
return self.update(request,*args,**kwargs) def delete(self, request, *args,**kwargs):
return self.destroy(request,*args,**kwargs)
以上增删改查有点问题
第二种封装方式 (generic)
url
from django.conf.urls import url
from django.contrib import admin from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
# url(r'^books/$', views.BookView.as_view()),
# url(r"^books/(\d+)/$", views.BookDetailView.as_view()), #第一种查询方式
# url(r"^publishes/$", views.PublishView.as_view()),
# url(r'^publishes/(\d+)/$', views.PublishDetailView.as_view()),
#第二种查询方式
url(r"^publishes/$", views.PublishViewSet.as_view()),
url(r'^publishes/(\d+)/$', views.PublishDetailViewSet.as_view()), #第三种查询方式(modelviewset)
# url(r'^authors/$', views.AuthorsModelView.as_view({"get": "list", "post": "create"}), ),
# url(r'^authors/(?P<pk>\d+)/$', views.AuthorsModelView.as_view({
# 'get': 'retrieve',
# 'put': 'update',
# 'delete': 'destroy'
# }), ), ]
views
# 通过Generics类的第二种方式增删改查#######################mixins【viewset】################################# from rest_framework import mixins
from rest_framework import generics -----------------------------序列化操作---------------------------------- class BookModelSerializers(ModelSerializer):
class Meta:
model = Publish
fields = "__all__" class PublishModelSerializers(ModelSerializer):
class Meta:
model = Publish
fields = "__all__" ----------------------------增删改查------------------------------------ class BookViewSet(generics.ListCreateAPIView): #查看、增加
queryset = Book.objects.all()
serializer_class = BookModelSerializers class BookDetailViewSet(generics.RetrieveUpdateDestroyAPIView): #删除更新
queryset = Book.objects.all()
serializer_class = BookModelSerializers ===================================================================== class PublishViewSet(generics.ListCreateAPIView):
queryset = Publish.objects.all()
serializer_class = PublishModelSerializers class PublishDetailViewSet(generics.RetrieveUpdateDestroyAPIView):
queryset = Publish.objects.all()
serializer_class = PublishModelSerializers
第三种封装(modelviewset)
url文件(红色部分)
from django.conf.urls import url
from django.contrib import admin from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
# url(r'^books/$', views.BookView.as_view()),
# url(r"^books/(\d+)/$", views.BookDetailView.as_view()), #第一种查询方式
# url(r"^publishes/$", views.PublishView.as_view()),
# url(r'^publishes/(\d+)/$', views.PublishDetailView.as_view()), #第二种查询方式
url(r"^publishes/$", views.PublishViewSet.as_view()),
url(r'^publishes/(\d+)/$', views.PublishDetailViewSet.as_view()), #第三种查询方式(modelviewset)
# url(r'^authors/$', views.AuthorsModelView.as_view({"get": "list", "post": "create"}), ),
# url(r'^authors/(?P<pk>\d+)/$', views.AuthorsModelView.as_view({
# 'get': 'retrieve',
# 'put': 'update',
# 'delete': 'destroy'
# }), ),
views逻辑部分
#通过mixins的第二种方式 查询增删改查(进一步优化)#######################mixins【viewset】################################# from rest_framework.viewsets import ModelViewSet class AuthorModelSerializers(ModelSerializer):
class Meta:
model = Publish
fields = "__all__" class AuthorsModelView(ModelViewSet):
queryset = Author.objects.all()
serializer_class = AuthorModelSerializers
day 94 RestFramework序列化组件与视图view的更多相关文章
- DjangoRestFramework学习二之序列化组件、视图组件 serializer modelserializer
DjangoRestFramework学习二之序列化组件.视图组件 本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组 ...
- 19.DjangoRestFramework学习二之序列化组件、视图组件
一 序列化组件 首先按照restful规范咱们创建一些api接口,按照下面这些形式写吧: Courses --- GET ---> 查看数据----->返回所有数据列表[{},{},] C ...
- day 88 DjangoRestFramework学习二之序列化组件、视图组件
DjangoRestFramework学习二之序列化组件.视图组件 本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组件 ...
- DjangoRestFramework学习二之序列化组件、视图组件
本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组件 首先按照restful规范咱们创建一些api接口,按照下面这些形式写吧: ...
- drf序列化组件之视图家族
一.视图家族的分类 1.导入分类 from rest_framewok import views, generics, mixins, viewsets views:视图类 两大视图类:APIVi ...
- Django rest-framework框架-组件之视图
视图: a. django class Test(View): ... b. rest_framework class Test(APIView): ... c. GenericAPIView 一般不 ...
- python全栈开发day99-DRF序列化组件
1.解释器组件源码分析 https://www.processon.com/view/link/5ba0a8e7e4b0534c9be0c968 2.基于CBV的接口设计 1).django循环que ...
- rest-framework之APIView 序列化组件
rest-framework之APIView 一 安装djangorestframework 方式一:pip3 install djangorestframework 方式二:pycharm图形化界面 ...
- rest-framework框架——APIView和序列化组件
一.快速实例 Quickstart http://www.cnblogs.com/yuanchenqi/articles/8719520.html restful协议 ---- 一切皆是资源,操作只是 ...
随机推荐
- [leetcode]112. Path Sum路径和(是否有路径)
Given a binary tree and a sum, determine if the tree has a root-to-leaf path such that adding up all ...
- 帧动画布局文件 animation-list
<?xml version="1.0" encoding="utf-8"?><animation-list xmlns:android=&qu ...
- 在控制台远程连接mysql数据库时,出现ERROR 2049 (HY000)错误
问题的原因是,你本地的数据库版本过高,而远程的数据库版本低. 解决方法:在连接时加上 --skip-secure-auth 参数就可以了. mysql -h主机 -u用户名 -p密码 --skip- ...
- Oracle增加一列、修改一列数据类型
Oracle增加一列.修改一列数据类型: 添加一列: alter table A add( CFYJSNR varchar2(20)); 修改列: alter table A ren ...
- 骗分大法之-----分块||迷之线段树例题a
什么是分块呢? 就是一种可以帮你骗到不少分的神奇的算法. 分块的写法有几种,我所知道的有①预处理②不预处理 不预处理的代码我看得一脸懵逼 所以我在这里就谈一下预处理的版本www 首先看一道题: 给定一 ...
- 8.15 自定义tr行 滚动 信息行的滚动
<table class="zixun-con-table"> <tr class="hover"> <th style=&quo ...
- java中配置JPA方法
JPA全称Java Persistence API.JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中 使用JPA进行保存对象时,可以用对象来接收,例 ...
- 2018.08.30 NOIP模拟 kfib(矩阵快速幂+exgcd)
[输入] 一行两个整数 n P [输出] 从小到大输出可能的 k,若不存在,输出 None [样例输入 1] 5 5 [样例输出] 2 [样例解释] f[0] = 2 f[1] = 2 f[2] = ...
- hdu-1129(模拟题)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1129 注意:c_code[i]=(p_code[i*k%n]-i)%28; #include<i ...
- changetoutf-8
import chardet import os # ANSI文件转UTF-8 import codecs import os def strJudgeCode(str): return charde ...