django drf to_internal_value

使用场景

用于将接收到的输入转换为内部可用的数据形式;

例子

to_internal_value主要在反序列化时用到,其作用处理API请求携带的数据,对其进行验证并转化为Python的数据类型。

假如我们的API客户端通过请求提交了额外的数据,比如extra_info字段,如下所示:

python 复制代码
{
    "extra_info": {
        "msg": "Hello world!",
    },

    "data": {
        "name ": "liuyongzhan",
        "status ": "active",
        "liked_by": [2, 3, 4]
    }
}

由于extra_info字段不属于我们TestSerializer类里的字段,如果我们直接使用TestSerializer类对上述数据进行反序列化会出现错误。

事实上反序列化时我们只需要提取data然后对其反序列化即可,所以我们可以重写to_internal_value提取我们所需要的数据,忽略不想要的数据。

python 复制代码
from django.db import models

class TestModel(models.Model):
   name = models.CharField(_("名称"), max_length=50, null=True, blank=True, default="")
   status = models.CharField(_("状态"), max_length=10, null=True)
   create_by = models.ForeignKey(to='users.User', on_delete=models.SET_NULL, null=True)
   liked_by = models.ManyToManyField(to='users.User')




from rest_framework import serializers


class TestSerializer(serializers.ModelSerializer):
  class Meta:
      model = TestModel
      fields = '__all__'

  def to_internal_value(self, data):
      # 提取所需要的数据,对其进行反序列化,data代表未验证的数据
      article_data = data['data']
      return super().to_internal_value(article_data)
相关推荐
归去来?22 分钟前
记录一次从https接口提取25G大文件csv并落表的经历
大数据·数据仓库·hive·python·网络协议·5g·https
喵手23 分钟前
Python爬虫零基础入门【第三章:Requests 静态爬取入门·第1节】你的第一个爬虫:抓取页面并保存 HTML!
爬虫·python·爬虫实战·python爬虫工程化实战·requests静态爬取·抓取网页并保存html·零基础入门python爬虫
喵手24 分钟前
Python爬虫零基础入门【第三章:Requests 静态爬取入门·第2节】伪装与会话:Headers、Session、Cookie(合规使用)!
爬虫·python·python爬虫实战·python爬虫工程化实战·requests静态爬取·伪装与会话·零基础python爬虫入门
小白学大数据1 小时前
绕过拼多多 App 反抓包机制的综合逆向解决方案
开发语言·爬虫·python·自动化
使者大牙1 小时前
【单点知识】 Python装饰器介绍
开发语言·数据库·python
Jackson@ML1 小时前
2026最新版Sublime Text 4安装使用指南
java·python·编辑器·sublime text
TonyLee0171 小时前
半监督学习介绍
人工智能·python·深度学习·机器学习
kong79069281 小时前
Python核心语法-Python自定义模块、Python包
开发语言·python·python核心语法
OLOLOadsd1231 小时前
基于Mask-RCNN和RegNetX的茎蛀虫检测识别系统详解
python
半路_出家ren2 小时前
1.古典密码概述
python·网络安全·密码学·古典密码·加密方式