Django框架model模型对象验证实现方法分析


Posted in Python onOctober 02, 2019

本文实例讲述了Django框架model模型对象验证实现方法。分享给大家供大家参考,具体如下:

模型对象的验证

验证一个模型涉及三个步骤:

  • 验证模型的字段 —— Model.clean_fields()
  • 验证模型的完整性 —— Model.clean()
  • 验证模型的唯一性 —— Model.validate_unique()

当调用模型的full_clean() 方法时,这三个方法都将执行。当使用ModelForm时,is_valid() 将为表单中的所有字段执行这些验证。如果你计划自己处理验证出现的错误,或者你已经将需要验证的字段从ModelForm 中去除掉,你只需调用模型的full_clean() 方法。

Model.full_clean(exclude=None, validate_unique=True)

该方法按顺序调用Model.clean_fields()、Model.clean() 和Model.validate_unique()(如果validate_unique 为True),并引发一个ValidationError,该异常的message_dict 属性包含三个步骤的所有错误。可选的exclude 参数用来提供一个可以从验证和清除中排除的字段名称的列表。ModelForm 使用这个参数来排除表单中没有出现的字段,使它们不需要验证,因为用户无法修正这些字段的错误。注意,当你调用模型的save() 方法时,full_clean() 不会 自动调用。如果你想一步就可以为你手工创建的模型运行验证,你需要手工调用它。例如:

from django.core.exceptions import ValidationError
try:
  article.full_clean()
except ValidationError as e:
  # Do something based on the errors contained in e.message_dict.
  # Display them to a user, or handle them programmatically.
  pass

full_clean() 第一步执行的是验证每个字段。

Model.clean_fields(exclude=None)

这个方法将验证模型的所有字段。可选的exclude 参数让你提供一个字段名称列表来从验证中排除。如果有字段验证失败,它将引发一个ValidationError。

full_clean() 第二步执行的是调用Model.clean()。如要实现模型自定义的验证,应该覆盖这个方法。

Model.clean()

应该用这个方法来提供自定义的模型验证,以及修改模型的属性。例如,你可以使用它来给一个字段自动提供值,或者用于多个字段需要一起验证的情形:

import datetime
from django.core.exceptions import ValidationError
from django.db import models
class Article(models.Model):
  ...
  def clean(self):
    # Don't allow draft entries to have a pub_date.
    if self.status == 'draft' and self.pub_date is not None:
      raise ValidationError('Draft entries may not have a publication date.')
    # Set the pub_date for published items if it hasn't been set already.
    if self.status == 'published' and self.pub_date is None:
      self.pub_date = datetime.date.today()

Model.full_clean() 类似,调用模型的save() 方法时不会引起clean() 方法的调用。

在上面的示例中,Model.clean() 引发的ValidationError 异常通过一个字符串实例化,所以它将被保存在一个特殊的错误字典键NON_FIELD_ERRORS中。这个键用于整个模型出现的错误而不是一个特定字段出现的错误:

from django.core.exceptions import ValidationError, NON_FIELD_ERRORS
try:
  article.full_clean()
except ValidationError as e:
  non_field_errors = e.message_dict[NON_FIELD_ERRORS]

若要引发一个特定字段的异常,可以使用一个字典实例化ValidationError,其中字典的键为字段的名称。我们可以更新前面的例子,只引发pub_date 字段上的异常:

class Article(models.Model):
  ...
  def clean(self):
    # Don't allow draft entries to have a pub_date.
    if self.status == 'draft' and self.pub_date is not None:
      raise ValidationError({'pub_date': 'Draft entries may not have a publication date.'})
    ...

最后,full_clean() 将检查模型的唯一性约束。

Model.validate_unique(exclude=None)

该方法与clean_fields() 类似,只是验证的是模型的所有唯一性约束而不是单个字段的值。可选的exclude 参数允许你提供一个字段名称的列表来从验证中排除。如果有字段验证失败,将引发一个 ValidationError。

注意,如果你提供一个exclude 参数给validate_unique(),任何涉及到其中一个字段的unique_together 约束将不检查。

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

Python 相关文章推荐
python算法学习之基数排序实例
Dec 18 Python
python连接mysql并提交mysql事务示例
Mar 05 Python
使用python检测主机存活端口及检查存活主机
Oct 12 Python
Python列表list解析操作示例【整数操作、字符操作、矩阵操作】
Jul 25 Python
Python使用asyncio包处理并发详解
Sep 09 Python
Python使用Selenium+BeautifulSoup爬取淘宝搜索页
Feb 24 Python
Python查找第n个子串的技巧分享
Jun 27 Python
详解Django 时间与时区设置问题
Jul 23 Python
利用ImageAI库只需几行python代码实现目标检测
Aug 09 Python
Python爬虫实现模拟点击动态页面
Mar 05 Python
python中的错误如何查看
Jul 08 Python
python入门:argparse浅析 nargs='+'作用
Jul 12 Python
Python 线程池用法简单示例
Oct 02 #Python
python multiprocessing多进程变量共享与加锁的实现
Oct 02 #Python
Python shutil模块用法实例分析
Oct 02 #Python
Windows平台Python编程必会模块之pywin32介绍
Oct 01 #Python
Python全栈之列表数据类型详解
Oct 01 #Python
python2和python3应该学哪个(python3.6与python3.7的选择)
Oct 01 #Python
使用Python制作一个打字训练小工具
Oct 01 #Python
You might like
php 生成唯一id的几种解决方法
2013/03/08 PHP
深入解析PHP 5.3.x 的strtotime() 时区设定 警告信息修复
2013/08/05 PHP
thinkphp中多表查询中防止数据重复的sql语句(必看)
2016/09/22 PHP
ThinkPHP5+Layui实现图片上传加预览功能
2018/08/17 PHP
整理8个很棒的 jQuery 倒计时插件和教程
2011/12/12 Javascript
JavaScript调用堆栈及setTimeout使用方法深入剖析
2013/02/16 Javascript
把input初始值不写value的具体实现方法
2013/07/04 Javascript
JS防止用户多次提交的简单代码
2013/08/01 Javascript
jquery中交替点击事件的实现代码
2014/02/14 Javascript
基于Bootstrap使用jQuery实现输入框组input-group的添加与删除
2016/05/03 Javascript
url中的特殊符号有什么含义(推荐)
2016/06/17 Javascript
JS+CSS3实现超炫的散列画廊特效
2016/07/16 Javascript
js 实现数值的千分位及保存小数方法(推荐)
2016/08/01 Javascript
javascript 组合按键事件监听实现代码
2017/02/21 Javascript
javascript checkbox/radio onchange不能兼容ie8处理办法
2017/06/13 Javascript
js实现登录注册框手机号和验证码校验(前端部分)
2017/09/28 Javascript
angular中子控制器向父控制器传值的实例
2018/10/08 Javascript
使用vue-cli webpack 快速搭建项目的代码
2018/11/21 Javascript
详解JavaScript 的变量
2019/03/08 Javascript
Node.js实现简单的爬取的示例代码
2019/06/25 Javascript
JavaScript实现拖拽效果
2020/03/16 Javascript
python批量下载图片的三种方法
2013/04/22 Python
python中os操作文件及文件路径实例汇总
2015/01/15 Python
Python中函数参数设置及使用的学习笔记
2016/05/03 Python
Windows下安装python MySQLdb遇到的问题及解决方法
2017/03/16 Python
django在保存图像的同时压缩图像示例代码详解
2020/02/11 Python
python使用Thread的setDaemon启动后台线程教程
2020/04/25 Python
python用tkinter实现一个简易能进行随机点名的界面
2020/09/27 Python
物流仓管员岗位职责
2013/12/04 职场文书
运动会入场解说词
2014/02/07 职场文书
2014学习优秀共产党员先进事迹思想汇报
2014/09/14 职场文书
金榜题名主持词
2015/07/02 职场文书
慰问信的写作格式及范文!
2019/06/24 职场文书
《孙子兵法》:欲成大事者,需读懂这些致胜策略
2019/08/23 职场文书
Redis Cluster集群动态扩容的实现
2021/07/15 Redis
HTML中link标签属性的具体用法
2023/05/07 HTML / CSS