pydantic 库 validator 的 per 参数:如何确保验证方法的正确执行顺序?

pydantic 库 validator 的 per 参数:如何确保验证方法的正确执行顺序?

pydantic 库 validator 的 per 参数问题

问题:

在使用 pydantic 库的 validator 装饰器时,将 per 参数设置为 true 并不是期望的验证方法执行顺序。

答案:

per 参数旨在设置验证器方法的执行顺序:

true:在标准验证器之前调用false:在标准验证器之后调用

但是,在某些情况下,可能会遇到 per 参数的执行顺序与预期不一致的情况。

原因:

这可能是因为你没有遵循官方指南中推荐的验证方法放置顺序。

解决方案:

为了确保正确的执行顺序,请遵循以下准则:

将带有 per=true 的验证器放在验证方法定义的开头。遵循此顺序:pre 验证器 -> 标准验证器 -> post 验证器

示例:

from pydantic import BaseModel, validator, ValidationErrorclass UserModel(BaseModel):    name: str    username: str    password1: str    password2: str    @validator('username', pre=True)  # 放在开头    def username_alphanumeric(cls, v, values):        print(values, '执行顺序优先')        assert v.isalnum(), 'must be alphanumeric'        return v    @validator('name')    def name_must_contain_space(cls, v, values):        print(values, 'name')        if ' ' not in v:            raise ValueError('must contain a space')        return v.title()    @validator('password2')    def passwords_match(cls, v, values):        print(values, 'password2')        if 'password1' in values and v != values['password1']:            raise ValueError('passwords do not match')        return vuser = UserModel(    name='samuel colvin',    username='scolvin',    password1='zxcvbn',    password2='zxcvbn',)

注意:

如果存在冲突,则可以在 pre 和 post 中使用多个验证器。如果希望验证器始终在标准验证器之后运行,可以省略 per 参数(默认为 false)。

以上就是pydantic 库 validator 的 per 参数:如何确保验证方法的正确执行顺序?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1352272.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 16:41:21
下一篇 2025年12月13日 16:41:28

相关推荐

发表回复

登录后才能评论
关注微信