Django:序列化的几种方法
前言
關(guān)于序列化操作,就是將一個可迭代的數(shù)據(jù)結(jié)構(gòu),通過便利的方式進(jìn)行我們所需要的操作。
今天歷來歸納一下,Django中的幾種不同得分方法,已經(jīng)Django-restframework提供的方法
創(chuàng)建一個Django的項目
新建一個app
創(chuàng)建一個模型,以書本出版社為例,自行遷移完成以后,再配置路由,主要講解的是views.py,其他的不多說了。
# RESFUL_DJ/app/models.pyfrom 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.nameclass Meta:db_table = 'db_publisher'verbose_name = "出版商"verbose_name_plural = verbose_name數(shù)據(jù)庫中的內(nèi)容(使用的是sqlite3)
現(xiàn)在我們來展示數(shù)據(jù)庫中的所有數(shù)據(jù),以json的格式傳給前端
RESTFUL_DJ/app/views.py
方法一:
from django.http import HttpResponsefrom app import modelsdef publisher_list(request):'''通過不同的方法,展示所有的出版社對象:param request: 請求:return: 出版社對象'''queryset = models.Publisher.objects.all()# 方法一data = []# 這個方法的缺點就是:# 如果字段多了的話,就需要一個一個去寫,會很麻煩# 返回的是字典類型,所以需要json轉(zhuǎn)換成json格式字符串for i in queryset:p_tmp = {"name": i.name,"address": i.address}data.append(p_tmp)import jsonreturn HttpResponse(json.dumps(data), content_type='application/json')?結(jié)果:
這是谷歌瀏覽器安裝的插件的原因,方便查看,原結(jié)構(gòu)是這樣:
方法二:
from django.http import HttpResponsefrom app import modelsdef publisher_list(request):'''通過不同的方法,展示所有的出版社對象:param request: 請求:return: 出版社對象'''queryset = models.Publisher.objects.all()# 方法二data = []# django自帶的模型轉(zhuǎn)字典方法# 缺點就是圖片之類的文件無法轉(zhuǎn)換# 返回的是字典類型,所以需要json轉(zhuǎn)換成json格式字符串from django.forms.models import model_to_dictfor i in queryset:data.append(model_to_dict(i))import jsonreturn HttpResponse(json.dumps(data), content_type='application/json')?結(jié)果:
方法三:
from django.http import HttpResponsefrom app import modelsdef publisher_list(request):'''通過不同的方法,展示所有的出版社對象:param request: 請求:return: 出版社對象'''queryset = models.Publisher.objects.all()# 方法三# 導(dǎo)入django自帶的序列化器# # 返回的是json字符串,不需要再用json轉(zhuǎn)換一次了from django.core import serializersdata = serializers.serialize('json', queryset)return HttpResponse(data, content_type='application/json')結(jié)果:
方法四:
首先需要安裝djangorestframework(pip install djangorestframework)
配置好settings.py文件
在app下新建文件serializers.py,(使用跟form差不多)
from rest_framework import serializers from app import modelsclass PublisherSerializer(serializers.Serializer): # 類的命名必須是models中的模型名稱加Seriaizerid = serializers.IntegerField(read_only=True)name = serializers.CharField(max_length=32)address = serializers.CharField(max_length=128)def create(self, validated_data):'''重寫create方法,創(chuàng)建數(shù)據(jù):param validated_data: 用戶傳遞的,經(jīng)過了校驗的數(shù)據(jù):return: 創(chuàng)建的數(shù)據(jù)'''return models.Publisher.objects.create(**validated_data)def update(self, instance, validated_data):'''更新數(shù)據(jù)操作:param instance: 原來的數(shù)據(jù):param validated_data: 用戶傳遞的,經(jīng)過了校驗的數(shù)據(jù):return: 更新后的數(shù)據(jù)'''instance.name = validated_data.get('name', instance.name)instance.address = validated_data.get('address', instance.address)instance.save()return instance??在shell中,測試一下展示操作
測試一下create共功能:
運(yùn)行項目,結(jié)果:
from django.shortcuts import render from django.http import HttpResponsefrom app import modelsdef publisher_list(request):'''通過不同的方法,展示所有的出版社對象:param request: 請求:return: 出版社對象'''queryset = models.Publisher.objects.all()# 方法四# 使用djangorestframework中的序列化from app import serializersserializer = serializers.PublisherSerializer(queryset, many=True) # 多個遍歷data = serializer.data # OrderedDict對象import jsonreturn HttpResponse(json.dumps(data), content_type='application/json')在前面創(chuàng)建的serializers.py文件中定義的序列化字段,其實和models中的模型字段是一樣的,我們可以繼承過來使用
繼承serializers.ModelSerializer方法,里面本身就封裝好了新建更新等數(shù)據(jù)操作的方法
更改serializers.py文件的內(nèi)容:
from rest_framework import serializers from app import modelsclass PublisherSerializer(serializers.ModelSerializer):class Meta:model = models.Publisherfields = ('id','name','address')總結(jié)
以上是生活随笔為你收集整理的Django:序列化的几种方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java基础—序列化底层原理
- 下一篇: (一)git简介及安装