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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...