官网地址:Serializers - Django REST framework
一、定义
# 序列化对象
serializer = StudentSerializer(comment)
serializer.data
# 定义Serializer
class StudentSerializer(serializers.ModelSerializer):
class ErrorMsg:
create_time_error = {"required": "创建时间不能为空!"}
name = {"required": "班级名称不能为空!", "max_length": "班级名称不能大于100字符!"}
create_time = serializers.IntegerField(required=True, error_messages=ErrorMsg.create_time_error)
name = serializers.CharField(max_length=100, required=True, error_messages=ErrorMsg.name)
date_method = serializers.SerializerMethodField()
# 定义验证
def validate_name(self, name):
"""
验证名称重复
:param name:
:return:
"""
if Student.objects.filter(name=name).count():
raise serializers.ValidationError("名称已存在")
return name
def get_date_method(self, obj):
"""
命名:get + 字段名
"""
return time.time() - 7 * 60
# 定义保存
def create(self, validated_data):
return Comment.objects.create(**validated_data)
# 定义更新
def update(self, instance, validated_data):
instance.email = validated_data.get('email', instance.email)
instance.content = validated_data.get('content', instance.content)
instance.created = validated_data.get('name', instance.created)
instance.save()
return instance
class Meta:
model = Student
fields = "__all__"
# fields = ("name", "age", "sex", "date_method")
# fields = '__all__': 表示所有字段
# exclude = ('add_time',): 除去指定的某些字段
read_only_fields = ('id', )
二、使用
# 创建新对象,save()
serializer = CommentSerializer(data=data)
if not serializer.is_valid():
return wrapper_500(serializer.errors)
serializer.save()
# 更新对象,save()
serializer = CommentSerializer(comment, data=data)
#有时,您希望您的视图代码能够在保存实例时,注入其他数据。此附加数据可能包括诸如当前用户,当前时间或不属于请求数据一部分的任何其他信息。
# 官网示例
serializer.save(owner=request.user)
# 不知道什么原因试了不好用,使用以下方法
data = request.data.copy()
data["user_id"] = "1"
# 部分更新,默认情况下,必须为所有必填字段传递序列化程序值,否则序列化程序会引发验证错误。可以使用partial参数来允许部分更新。
serializer = CommentSerializer(comment, data={'content': 'foo bar'}, partial=True)
三、扩展模型基类示例,开始时间、结束时间
class BaseModel(models.Model):
create_time = models.DateTimeField(auto_now_add=True)
update_time = models.DateTimeField(auto_now=True)
class Meta:
abstract = True # 说明是抽象类模型,可用于继承,数据库迁移时不会创建表