前言
关于序列化操作,就是将一个可迭代的数据结构,通过便利的方式进行我们所需要的操作。
今天历来归纳一下,Django中的几种不同得分方法,已经Django-restframework提供的方法
创建一个Django的项目
再新建一个app
创建一个模型,以书本出版社为例,自行迁移完成以后,再配置路由,主要讲解的是views.py,其他的不多说了。
# RESFUL_DJ/app/models.pyfrom django.db importmodels#Create your models here.
classPublisher(models.Model):
name= models.CharField(max_length=32, verbose_name='名称', unique=True)
address= models.CharField(max_length=128, verbose_name='地址')def __str__(self):returnself.nameclassMeta:
db_table= 'db_publisher'verbose_name= "出版商"verbose_name_plural= verbose_name
数据库中的内容(使用的是sqlite3)
现在我们来展示数据库中的所有数据,以json的格式传给前端
RESTFUL_DJ/app/views.py
方法一:
from django.http importHttpResponsefrom app importmodelsdefpublisher_list(request):'''通过不同的方法,展示所有的出版社对象
:param request: 请求
:return: 出版社对象'''queryset=models.Publisher.objects.all()#方法一
data =[]#这个方法的缺点就是:
#如果字段多了的话,就需要一个一个去写,会很麻烦
#返回的是字典类型,所以需要json转换成json格式字符串
for i inqueryset:
p_tmp={"name": i.name,"address": i.address
}
data.append(p_tmp)importjsonreturn HttpResponse(json.dumps(data), content_type='application/json')
结果:
这是谷歌浏览器安装的插件的原因,方便查看,原结构是这样:
方法二:
from django.http importHttpResponsefrom app importmodelsdefpublisher_list(request):'''通过不同的方法,展示所有的出版社对象
:param request: 请求
:return: 出版社对象'''queryset=models.Publisher.objects.all()#方法二
data =[]#django自带的模型转字典方法
#缺点就是图片之类的文件无法转换
#返回的是字典类型,所以需要json转换成json格式字符串
from django.forms.models importmodel_to_dictfor i inqueryset:
data.append(model_to_dict(i))importjsonreturn HttpResponse(json.dumps(data), content_type='application/json')
结果:
方法三:
from django.http importHttpResponsefrom app importmodelsdefpublisher_list(request):'''通过不同的方法,展示所有的出版社对象
:param request: 请求
:return: 出版社对象'''queryset=models.Publisher.objects.all()#方法三
#导入django自带的序列化器
## 返回的是json字符串,不需要再用json转换一次了
from django.core importserializers
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 importserializersfrom app importmodelsclassPublisherSerializer(serializers.Serializer): # 类的命名必须是models中的模型名称加Seriaizer
id= serializers.IntegerField(read_only=True)
name= serializers.CharField(max_length=32)
address= serializers.CharField(max_length=128)defcreate(self, validated_data):'''重写create方法,创建数据
:param validated_data: 用户传递的,经过了校验的数据
:return: 创建的数据'''
return models.Publisher.objects.create(**validated_data)defupdate(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 importrenderfrom django.http importHttpResponsefrom app importmodelsdefpublisher_list(request):'''通过不同的方法,展示所有的出版社对象
:param request: 请求
:return: 出版社对象'''queryset=models.Publisher.objects.all()#方法四
#使用djangorestframework中的序列化
from app importserializers
serializer= serializers.PublisherSerializer(queryset, many=True) #多个遍历
data = serializer.data #OrderedDict对象
importjsonreturn HttpResponse(json.dumps(data), content_type='application/json')
在前面创建的serializers.py文件中定义的序列化字段,其实和models中的模型字段是一样的,我们可以继承过来使用
继承serializers.ModelSerializer方法,里面本身就封装好了新建更新等数据操作的方法
更改serializers.py文件的内容:
from rest_framework importserializersfrom app importmodelsclassPublisherSerializer(serializers.ModelSerializer):classMeta:
model=models.Publisher
fields=('id','name','address')
结果:
还是没有问题,可以使用的。