序列化类高级用法之source
使用source,字段参数,可以修改序列化字段名字
原本序列化器中字段名,必须和表中的字段名一样,不一样会报错
我们可以通过source字段来改变序列化器中的字段名,使得前端在展示的时候也修改一下字段名!!
source也可以做跨表查询,通过外键字段,表名点外键出去的字段名字
class BookSerializer(serializers.Serializer):
publish=serializers.CharField(source='publish.email')
# 等价于book.publish.email 查到当前书对象的文键出版社对象然后拿到该出版社对象的邮箱
source指定的可以是字段,也可以是方法,用于重命名
小坑:不能够指定它原本的名字
序列化类高级用法之定制序列化字段的俩种方式
方式一:在【序列化类】中写SerializerMethodField
必须配合一个方法(get_字段名,需要传一个字段名接受一个参数),方法返回什么,这个字段就是什么
class BookSerializer(serializers.Serializer):
name = serializers.CharField(max_length=8, min_length=3)
price = serializers.IntegerField(max_value=300, min_value=10)
# publish = serializers.CharField(max_length=8, min_length=3)
# publish要序列化成{name:北京出版社,city:北京,email:2@qq.com}
# 方式一:SerializerMethodField必须配合一个方法(get_字段名,需要传一个字段名接受一个参数),方法返回什么,这个字段就是什么
publish = serializers.SerializerMethodField()
def get_publish(self, obj):
# obj 就是当前序列化的对象
return {'name': obj.publish.name, 'city': obj.publish.city, 'email': obj.publish.email} # 基于对象的跨表查询
# 练习一
author = serializers.SerializerMethodField()
def get_author(self, obj):
res_list = []
for author in obj.authors.all():
res_list.append({'id': author.id, 'name': author.name, 'age': author.age})
return res_list
assert断言
# 框架的源码中,大量使用断言
# assert :断言,作用的判断,断定一个变量必须是xx,如果不是就报错
# 你的土鳖写法
# name = 'lqz1'
# if not name == 'lqz':
# raise Exception('name不等于lqz')
#
# print('程序执行完了')
# assert的断言写法
name = 'lqz1'
assert name == 'lqz', 'name不等于lqz'
print('程序执行完了')