序列化反序列化

加载模块:

from django.core import serializers
# get请求通过HttpResponse方式返回数据
class Books2(APIView):
  def get(self,request):
     book_list=models.Book.objects.all()    # 查询所有数据
      # serializers.serialize使用django内置的serialize方法,把QuserySet对象转换为json格式
      res = serializers.serialize("json",book_list)    
      return HttpResponse(res)

前端数据展示:

    

缺点:会把一些无用的数据全部展示出去,包括库名字,表名字,不能够展示单独的字段信息

 

序列化组件:

    Python中的对象转换为json格式的字符串

    注意:前后端分离,不能只能直接反序列,json不能序列化对象,只能序列化字典和列表

 

 

添加model(生成数据库表格字段)

class Book(models.Model):
  id = models.AutoField(primary_key=True)
  name = models.CharField(max_length=32)
  price = models.DecimalField(max_digits=5, decimal_places=2)
   publish_date = models.DateField(null=True)
   xx=models.IntegerField(choices=((0,'文学类'),(1,'情感类')),default=1,null=True)
   publish = models.ForeignKey(to='Publish',to_field='id',on_delete=models.CASCADE,null=True)
   authors=models.ManyToManyField(to='Author')
   def __str__(self):
     return self.name
class Author(models.Model):
  id = models.AutoField(primary_key=True)
   age = models.IntegerField()
class Publish(models.Model):
   id = models.AutoField(primary_key=True)
   name = models.CharField(max_length=32)
   city = models.CharField(max_length=32)
   email = models.EmailField()
  def __str__(self):
     return self.name

 

新增一个文件:

    例如:app01Serializer.py

from rest_framework import serializers
class BookSerializer(serializers.Serializer):
  name=serializers.CharField()
  # price=serializers.DecimalField()
  price=serializers.CharField()

其中name和price都是表字段

 

在视图文件views.py中创建类

添加模块:

from rest_framework.views import APIView
from rest_framework.response import Response
from app01 import models
from app01.app01Serializer import BookSerializer

# 把对象转换成json字符串

class Books(APIView):
  def get(self,request):
  books = models.Book.objects.all()
  # 当序列化一条数据的时候many=True可以不写,序列化多条数据的时候(也就是queryset对象)必须要写
  bookser=BookSerializer(books,many=True)
  print(type(bookser.data))
  return Response(bookser.data)

 

前端访问:自带页面,只会展示我在app01Serializer.py文件中定序列化的字段

 

 

设置别名:避免前端直接看到数据的字段名:

# 指定source='name',表示序列化模型表中的name字段,重命名为name5或者别的名字(自定义)

 

修改app01Serializer.py文件

原字段是name,设置成别名为'书名'

重新启动服务web查看获取的数据样式:

根据book表中的publish_id字段和publish(出版社)的id字段进行关联,查询显示该书对应的出版社和城市

 

和上面设置别名一样,通过本表中的关联字段点方法获取关联表的指定字段

查看效果:

Source不仅可以指定一个字段,还可以指定一个方法

表格字段设置:

xx=models.IntegerField(choices=((0,'文学类'),(1,'情感类')),default=1,null=True)

在app01Serializer.py文件中设置xx字段序列化设置:

book_type = serializers.CharField(source='get_xx_display')

查看数据展示效果:

在数据库存储的是对应的选项,数据展示的是对应的值

 

 

 

序列化出版社的详细信息,指定SerializerMethodField之后,可以对应一个方法,返回什么内容,publish_detail就是什么内容

publish_detail = serializers.SerializerMethodField()
def get_publish_detail(self,obj):
  return {'name':obj.publish.name,'city':obj.publish.city,'email':obj.publish.email}

展示效果:

    

返回作者的信息:

方式一:

    

 

方式二:

 

 

Write_only与read_only

当设置write_only=True序列化的时候,该字段不显示

当设置read_only=True 反序列化的时候,该字段不传

 

 

 

 

 

 

设置深度打印表及关联表的全部信息:

前端展示数据(depth=1,深度不建议超过10,个人建议不超过3):

 

数据显示:

Fields设置显示数据,可以显示全部也可以显示一部分

Exclude与fields相反,设置不显示的字段

#注意:fields与exclude不能同时使用

 

继承ModelSerializers序列化类的对象,反序列化

数据新增成功:

    

反序列化对数据进行效验:

    局部校验:

    判断name字段是否是以sb开头

    

测试插入数据name字段的带有sb开头数据,查看是否插入成功

插入数据成功

插入数据失败

 

    全局校验:

可以针对获取的值进行判断

posted @ 2019-07-03 16:52  阳光与叶子  阅读(304)  评论(0编辑  收藏  举报