本站资源收集于互联网,不提供软件存储服务,每天免费更新优质的软件以及学习资源!

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

网络教程 app 1℃

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 参数:如何确保验证方法的正确执行顺序?的详细内容,更多请关注范的资源库其它相关文章!

转载请注明:范的资源库 » pydantic库validator的per参数:如何确保验证方法的正确执行顺序?

喜欢 (0)