美文网首页
Django-->Serializer序列化器

Django-->Serializer序列化器

作者: fe3e18c7aab5 | 来源:发表于2019-05-31 14:36 被阅读0次

    模型类用例

    这里设置一个Django ORM用来当作下面的测试用例

    class StudentInfo(models.Model):
        name = models.CharField(max_length=20, verbose_name='姓名')
        birthday = models.DateField(verbose_name='生日', null=True)
        money = models.IntegerField(default=0, verbose_name='现金')
        image = models.ImageField(upload_to='studenttest', verbose_name='照片', null=True)
    

    1. 手动定义一个序列化器

    • Django REST framework中的Serializer使用类来定义,须继承自rest_framework.serializers.Serializer
    • 注意: serializer不是只能为数据库模型类定义,也可以为非数据库模型类的数据定义.serializer是独立于数据库之外的存在
    #导入父类进行继承
    from rest_framework import serializers
    
    class StudentSerializer(serializers.Serializer)
        id = serializers.IntegerField(label='ID', read_only=True)
        name = serializers.CharField(label='姓名', max_length=20)
        birthday = serializers.DateField(label='生日', required=False)
        money = serializers.IntegerField(label='现金', required=False)
        image = serializers.ImageField(label='照片', required=False)
    

    2. 序列化器的字段与选项

    • 字段
    CharField: CharField(max_length=None, min_length=None, allow_blank=False, trim_whitespace=True)
    IntegerField: IntegerField(max_value=None, min_value=None)
    BooleanField: BooleanField()
    NullBooleanField: NullBooleanField()
    EmailField: EmailField(max_length=None, min_length=None, allow_blank=False)
    RegexField: RegexField(regex, max_length=None, min_length=None, allow_blank=False)
    SlugField: SlugField(maxlength=50, min_length=None, allow_blank=False)正则字段,验证正则模式 [a-zA-Z0-9-]+
    URLField: URLField(max_length=200, min_length=None, allow_blank=False)
    IPAddressField: IPAddressField(protocol='both', unpack_ipv4=False, **options)
    IntegerField: IntegerField(max_value=None, min_value=None)
    FloatField: FloatField(max_value=None, min_value=None)
    DecimalField: DecimalField(max_digits, decimal_places, coerce_to_string=None, max_value=None, min_value=None)          max_digits: 最多位数,decimal_palces: 小数点位置
    DateTimeField: DateTimeField(format=api_settings.DATETIME_FORMAT, input_formats=None)
    DateField: DateField(format=api_settings.DATE_FORMAT, input_formats=None)
    TimeField: TimeField(format=api_settings.TIME_FORMAT, input_formats=None)
    DurationField: DurationField()
    ChoiceField: ChoiceField(choices)      choices与Django的用法相同
    MultipleChoiceField: MultipleChoiceField(choices)
    FileField: FileField(max_length=None, allow_empty_file=False,use_url=UPLOADED_FILES_USE_URL)
    ImageField: ImageField(max_length=None,allow_empty_file=False,use_url=UPLOADED_FILES_USE_URL)
    ListField: ListField(child=, min_length=None, max_length=None)
    DictField: DictField(child=)
    
    • 选项
    max_length: 最大长度
    min_lenght: 最小长度
    allow_blank: 是否允许为空
    trim_whitespace: 是否截断空白字符
    max_value: 最小值
    min_value: 最大值
    
    • 通用选项
    read_only: 表明该字段仅用于序列化输出,默认False
    write_only: 表明该字段仅用于反序列化输入,默认False
    required: 表明该字段在反序列化时必须输入,默认True
    default: 反序列化时使用的默认值
    allow_null: 表明该字段是否允许传入None,默认False
    validators: 该字段使用的验证器
    error_messages: 包含错误编号与错误信息的字典
    label: 用于HTML展示API页面时,显示的字段名称
    help_text: 用于HTML展示API页面时,显示的字段帮助提示信息
    

    3. 创建Serializer对象

    Serializer的构造方法为:

    Serializer(instance=None, data=empty, **kwarg)
    
    • instance: 序列化时传入的模型类对象
    • data: 反序列化是需要传入的数据
    • 除了instancedata参数外,在构造Serializer对象时,还可通过context参数额外添加数据,如serializer = AccountSerializer(account, context={'request': request})通过context参数附加的数据,可以通过Serializer对象的context属性获取

    相关文章

      网友评论

          本文标题:Django-->Serializer序列化器

          本文链接:https://www.haomeiwen.com/subject/zmwwtctx.html