python3-開發進階Django中序列化以及rest_framework的序列化

来源:https://www.cnblogs.com/ManyQian/archive/2018/08/02/9410608.html
-Advertisement-
Play Games

一、django框架的序列化 直接上代碼 1、這是app下的models.py 2、這是app下的view.py,兩種序列化方法 總結: 我們會發現序列化出來的數據比較單一,返回來的樣式太麻煩,而django自帶的方法,而且無法反序列化! 二、rest_framework中的序列化組件 首先我們要先 ...


一、django框架的序列化

直接上代碼

1、這是app下的models.py

from django.db import models

# Create your models here.



class Course(models.Model):
    title=models.CharField(max_length=32)

2、這是app下的view.py,兩種序列化方法

from django.views import View
from app01.models import Course


class CourseView(View):

    def get(self,request):

        ret=Course.objects.all()
        #這是我們自己用json模塊去序列化數據
        #import json
        #temp=[] 
        # for i in ret:
        #     temp.append({
        #         "title":i.title
        #    })

        #這是django自帶的
         from django.core.serializers import serialize
         ret=serialize("json",ret)

         # return HttpResponse(temp)     
         return HttpResponse(ret)

總結:

  我們會發現序列化出來的數據比較單一,返回來的樣式太麻煩,而django自帶的方法,而且無法反序列化!

二、rest_framework中的序列化組件

 首先我們要先下載這個模塊

pip3 install djangorestframework

裝好之後,不要忘了在app中註冊rest_framework,

from rest_framework.views import APIView
from rest_framework.response import Response
from .models import *
from django.shortcuts import HttpResponsefrom rest_framework import serializers

class BookSerializers(serializers.Serializer):  
    title=serializers.CharField(max_length=32)
    price=serializers.IntegerField()
    pub_date=serializers.DateField()
    publish=serializers.CharField(source="publish.name")
    #authors=serializers.CharField(source="authors.all")
    authors=serializers.SerializerMethodField()
    def get_authors(self,obj):
        temp=[]
        for author in obj.authors.all():
            data=[]
       data.append(author.pk) 
       data.append(author.name)
       temp.append(data)
return temp class BookViewSet(APIView): def get(self,request,*args,**kwargs): book_list=Book.objects.all() bs=BookSerializers(book_list,many=True) return Response(bs.data)

我們這裡有更簡便的方法:

from rest_framework import serializers
from app01.models import Book
class BookSerializers(serializers.ModelSerializer):
    class Meta:
        model=Book
        fields="__all__"

 五種狀態的標準形式

class BookView(APIView):

    def get(self, request):
        book_list = Book.objects.all()
        bs = BookSerializers(book_list, many=True)
        # 序列化數據
        return Response(bs.data)

    def post(self, request):
        # 添加一條數據
        print(request.data)
        bs=BookSerializers(data=request.data)
        if bs.is_valid():
            bs.save()  # 生成記錄
            return Response(bs.data)
        else:
            return Response(bs.errors)

class BookDetailView(APIView):
    def get(self,request,pk):
        book_obj=Book.objects.filter(pk=pk).first()
        bs=BookSerializers(book_obj,many=False)
        return Response(bs.data)

    def put(self,request,pk):
        book_obj = Book.objects.filter(pk=pk).first()
        bs=BookSerializers(data=request.data,instance=book_obj)#instance
        if bs.is_valid():
            bs.save() # update
            return Response(bs.data)
        else:
            return Response(bs.errors)

    def delete(self,request,pk):
        Book.objects.filter(pk=pk).delete()
        return Response("")

我們再創建一張表,我們會發現代碼有點冗餘了,除了變數名的變化,這裡也有封好的方法mixin類

from rest_framework import mixins
from rest_framework import generics

class BookViewSet(mixins.ListModelMixin,
                  mixins.CreateModelMixin,
                  generics.GenericAPIView):

    queryset = Book.objects.all()
    serializer_class = BookSerializers

    def get(self, request, *args, **kwargs):
        return self.list(request, *args, **kwargs)

    def post(self, request, *args, **kwargs):
        return self.create(request, *args, **kwargs)



class BookDetailViewSet(mixins.RetrieveModelMixin,
                    mixins.UpdateModelMixin,
                    mixins.DestroyModelMixin,
                    generics.GenericAPIView):
    queryset = Book.objects.all()
    serializer_class = BookSerializers

    def get(self, request, *args, **kwargs):
        return self.retrieve(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)

我們在上面的幾個類中,我們下來翻看源碼:

from rest_framework.mixins import CreateModelMixin
from rest_framework.mixins import ListModelMixin
from rest_framework.mixins import DestroyModelMixin
from rest_framework.mixins import RetrieveModelMixin
from rest_framework.mixins import UpdateModelMixin

我們先來看CreateModeMixin類的源碼,我們發現 create 

ListModeMixin類的源碼,我們發現list

 

RetrieveModelMixin類的源碼,我們發現retrieve

UpdateModelMixin類的源碼,我們發現update

 

DestroyModelMixin類的源碼,我們發現destroy

然後我們可以這樣封裝:

from rest_framework.mixins import CreateModelMixin,ListModelMixin,DestroyModelMixin,RetrieveModelMixin,UpdateModelMixin
from rest_framework import generics

class BookView(CreateModelMixin,ListModelMixin,generics.GenericAPIView,):

    queryset=Book.objects.all()
    serializer_class=BookSerializers

    def get(self,request):
        return self.list(request)

    def post(self,request):

        return self.create(request)

class BookDetailView(DestroyModelMixin,UpdateModelMixin,RetrieveModelMixin,generics.GenericAPIView,):
    queryset = Book.objects.all()
    serializer_class = BookSerializers

    def get(self,request, *args, **kwargs):

       return self.retrieve(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)

發現代碼還是冗餘的,我們還有更簡便的方法,REST框架提供了簡化的view.py模塊

from rest_framework import mixins
from rest_framework import generics

class BookViewSet(generics.ListCreateAPIView):

    queryset = Book.objects.all()
    serializer_class = BookSerializers

class BookDetailViewSet(generics.RetrieveUpdateDestroyAPIView):
    queryset = Book.objects.all()
    serializer_class = BookSerializers

class PublishViewSet(generics.ListCreateAPIView):

    queryset = Publish.objects.all()
    serializer_class = PublshSerializers

class PublishDetailViewSet(generics.RetrieveUpdateDestroyAPIView):
    queryset = Publish.objects.all()
    serializer_class = PublshSerializers

需要什麼樣的方法,就繼承什麼方法類,但裡面的方法需要在url傳入需要的參數

#views中代碼非常簡介,最重要的還是urls
from rest_framework.viewsets import ModelViewSet

class AuthorModelView(ModelViewSet):

    queryset=Author.objects.all()
    serializer_class=AuthorSerializers
from django.conf.urls import url
from django.contrib import admin
from app01 import views

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    #在as_view中加入參數
    url(r'^authors/$', views.AuthorModelView.as_view({"get":"list","post":"create"})),
    url(r'^authors/(?P<pk>\d+)/$', views.AuthorModelView.as_view({"get":"retrieve","put":"update","delete":"destroy"})),
]

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 5.1.threading模塊 簡單使用 5.2.生產者和消費者 Lock模式的生產者和消費者 5.3.下載表情包 網址:http://www.doutula.com/photo/list/?page=1 解析:xpath 不用多線程,速度相對會很慢 利用多線程 main() 定義兩個隊列,和創建多 ...
  • 在上一章中,我們已經創建好ORM的基類了,接下來要做的就是將基類的常用方法一一實現。 首先我們來看看之前項目中,最常見的獲取指定主鍵的記錄實體 從代碼中可以看到,我們需要執行select * from product where id = xx從數據表中查詢到我們想要的數據。 要封裝成ORM的方法, ...
  • malloc 函數 n為要分配的位元組數,如果成功,返回獲得空間的首地址,如果分配失敗,則返回NULL,malloc分配的記憶體是未初始化過的,所以必須用memset初始化 在s指向的的地址,填充n個ch malloc分配的是堆上的記憶體,顯式調用free來釋放 calloc 函數 calloc函數和ma ...
  • 1)字元串操作 strcpy(p, p1) 複製字元串 strncpy(p, p1, n) 複製指定長度字元串 strcat(p, p1) 附加字元串 strncat(p, p1, n) 附加指定長度字元串 strlen(p) 取字元串長度 strcmp(p, p1) 比較字元串 strcasecm ...
  • 在使用Python做開發的時候,時不時會給自己編寫了一些小工具輔助自己的工作,但是由於開發依賴環境問題,多數只能在自己電腦上運行,拿到其它電腦後就沒法運行了。這顯得很不方便,不符合我們的初衷,那麼有沒有一種什麼辦法可以使我們編寫好的程式,可以直接在各種windows下運行的呢? 答案是:有的,說到w ...
  • 1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 # Author:Caesar yang 4 5 import getpass #導入模塊隱藏密碼 6 count = 0 #定義計數器 7 while count < 3: 8 name = i ...
  • 雖然C++中的類型是強制聲明的,但是這並不意味著不同類型之間不可以進行一些計算或賦值。 我們來看下麵的一組代碼 上面的賦值語句中,沒有一個是在把對應的值賦值給對應的類型。 但是並沒有產生編譯的錯誤,我們曾經說過,C++是一種強類型的語言。 這樣胡亂的賦值感覺並不是強類型啊! 事情是這樣的,類型指一個 ...
  • 這裡搞一個測試場景: 用戶和訂單,一位用戶可以有多個訂單,而每個訂單隻屬於一位用戶 以用戶為中心,相對於訂單:一對多 以訂單為中心,當對於用戶:一對一 兩張表結構: 訂單表: 用戶表: 對應的POJO類: User: package pojo; import java.io.Serializable ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...