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

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

pydantic 库 validator 的 per 参数问题

问题:

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

答案:

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

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

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

原因:

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

解决方案:

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

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

示例:

from pydantic import BaseModel, validator, ValidationError

class 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 v

user = UserModel(
    name='samuel colvin',
    username='scolvin',
    password1='zxcvbn',
    password2='zxcvbn',
)

注意:

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

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