python测试开发django-rest-framework-85.序列化(ModelSerializer)之设置必填(required)和非必填字段

前言

在使用 django-rest-framework 开发接口的时候,我们希望能设置有些字段是必填字段,有些字段是非必填字段。
在使用ModelSerializer 序列化的时候,可以个字段加一个 required 参数 设置 True 或 False 。

ModelSerializer 序列化

接着前面一篇,设置日期时间格式后,发现这2个字典是必填项了

from rest_framework import serializers

class GoodsAPISerializer(serializers.ModelSerializer):
    # 设置创建时间和更新时间格式化
    create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S')
    update_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S')

    class Meta:
        model = Goods
        fields = '__all__'  # 返回全部的字段

提交数据后返回 create_time 和 update_time 是必填项

{
	"code": 3003,
	"msg": "参数不合法",
	"data": {
		"create_time": ["该字段是必填项。"],
		"update_time": ["该字段是必填项。"]
	}
}

设置非必填项 required=False

如果我们想设置某个字段是非必填项,在ModelSerializer序列化的时候,只需加一个参数 required=False

from rest_framework import serializers
# 作者-上海悠悠 QQ交流群:717225969
# blog地址 https://www.cnblogs.com/yoyoketang/

class GoodsAPISerializer(serializers.ModelSerializer):
    create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
    update_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)

    class Meta:
        model = Goods
        fields = '__all__'  # 返回全部的字段

接下来再提交数据的时候,就不用传 create_time 和 update_time 参数了

设置必填项 required=True

我们也可以设置其他字段是必填项,在ModelSerializer序列化的时候,只需加一个参数 required=True

from rest_framework import serializers
# 作者-上海悠悠 QQ交流群:717225969
# blog地址 https://www.cnblogs.com/yoyoketang/

class GoodsAPISerializer(serializers.ModelSerializer):
    create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
    update_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)

    # 设置必填项
    stock = serializers.IntegerField(required=True)

    class Meta:
        model = Goods
        fields = '__all__'  # 返回全部的字段

接下来提交数据的时候,不带 stock 字段就会提示:该字段是必填项。

{
	"code": 3003,
	"msg": "参数不合法",
	"data": {
		"stock": ["该字段是必填项。"]
	}
}
posted @   上海-悠悠  阅读(2224)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2019-01-18 Linux学习19-gitlab配置邮箱postfix(新用户激活邮件)
2018-01-18 python笔记9-多线程Threading之阻塞(join)和守护线程(setDaemon)
点击右上角即可分享
微信分享提示