前言
關於序列化操作,就是將一個可迭代的數據結構,通過便利的方式進行我們所需要的操作。
今天歷來歸納一下,Django中的幾種不同得分方法,已經Django-restframework提供的方法
創建一個Django的項目
再新建一個app

創建一個模型,以書本出版社為例,自行遷移完成以后,再配置路由,主要講解的是views.py,其他的不多說了。
# RESFUL_DJ/app/models.py
from django.db import models # Create your models here. class Publisher(models.Model): name = models.CharField(max_length=32, verbose_name='名稱', unique=True) address = models.CharField(max_length=128, verbose_name='地址') def __str__(self): return self.name class Meta: db_table = 'db_publisher' verbose_name = "出版商" verbose_name_plural = verbose_name
數據庫中的內容(使用的是sqlite3)

現在我們來展示數據庫中的所有數據,以json的格式傳給前端
RESTFUL_DJ/app/views.py
方法一:
from django.http import HttpResponse
from app import models
def publisher_list(request):
'''
通過不同的方法,展示所有的出版社對象
:param request: 請求
:return: 出版社對象
'''
queryset = models.Publisher.objects.all()
# 方法一
data = []
# 這個方法的缺點就是:
# 如果字段多了的話,就需要一個一個去寫,會很麻煩
# 返回的是字典類型,所以需要json轉換成json格式字符串
for i in queryset:
p_tmp = {
"name": i.name,
"address": i.address
}
data.append(p_tmp)
import json
return HttpResponse(json.dumps(data), content_type='application/json')
結果:

這是谷歌瀏覽器安裝的插件的原因,方便查看,原結構是這樣:

方法二:
from django.http import HttpResponse
from app import models
def publisher_list(request):
'''
通過不同的方法,展示所有的出版社對象
:param request: 請求
:return: 出版社對象
'''
queryset = models.Publisher.objects.all()
# 方法二
data = []
# django自帶的模型轉字典方法
# 缺點就是圖片之類的文件無法轉換
# 返回的是字典類型,所以需要json轉換成json格式字符串
from django.forms.models import model_to_dict
for i in queryset:
data.append(model_to_dict(i))
import json
return HttpResponse(json.dumps(data), content_type='application/json')
結果:

方法三:
from django.http import HttpResponse
from app import models
def publisher_list(request):
'''
通過不同的方法,展示所有的出版社對象
:param request: 請求
:return: 出版社對象
'''
queryset = models.Publisher.objects.all()
# 方法三
# 導入django自帶的序列化器
# # 返回的是json字符串,不需要再用json轉換一次了
from django.core import serializers
data = serializers.serialize('json', queryset)
return HttpResponse(data, content_type='application/json')
結果:

方法四:
首先需要安裝djangorestframework(pip install djangorestframework)

配置好settings.py文件
在app下新建文件serializers.py,(使用跟form差不多)
from rest_framework import serializers
from app import models
class PublisherSerializer(serializers.Serializer): # 類的命名必須是models中的模型名稱加Seriaizer
id = serializers.IntegerField(read_only=True)
name = serializers.CharField(max_length=32)
address = serializers.CharField(max_length=128)
def create(self, validated_data):
'''
重寫create方法,創建數據
:param validated_data: 用戶傳遞的,經過了校驗的數據
:return: 創建的數據
'''
return models.Publisher.objects.create(**validated_data)
def update(self, instance, validated_data):
'''
更新數據操作
:param instance: 原來的數據
:param validated_data: 用戶傳遞的,經過了校驗的數據
:return: 更新后的數據
'''
instance.name = validated_data.get('name', instance.name)
instance.address = validated_data.get('address', instance.address)
instance.save()
return instance
在shell中,測試一下展示操作

測試一下create共功能:

運行項目,結果:

from django.shortcuts import render
from django.http import HttpResponse
from app import models
def publisher_list(request):
'''
通過不同的方法,展示所有的出版社對象
:param request: 請求
:return: 出版社對象
'''
queryset = models.Publisher.objects.all()
# 方法四
# 使用djangorestframework中的序列化
from app import serializers
serializer = serializers.PublisherSerializer(queryset, many=True) # 多個遍歷
data = serializer.data # OrderedDict對象
import json
return HttpResponse(json.dumps(data), content_type='application/json')

在前面創建的serializers.py文件中定義的序列化字段,其實和models中的模型字段是一樣的,我們可以繼承過來使用


繼承serializers.ModelSerializer方法,里面本身就封裝好了新建更新等數據操作的方法
更改serializers.py文件的內容:
from rest_framework import serializers
from app import models
class PublisherSerializer(serializers.ModelSerializer):
class Meta:
model = models.Publisher
fields = (
'id',
'name',
'address'
)
結果:


