pydantic 库 validator 的 per 参数问题
问题:
在使用 pydantic 库的 validator 装饰器时,将 per 参数设置为 true 并不是期望的验证方法执行顺序。
答案:
per 参数旨在设置验证器方法的执行顺序:
- true:在标准验证器之前调用
- false:在标准验证器之后调用
但是,在某些情况下,可能会遇到 per 参数的执行顺序与预期不一致的情况。
原因:
这可能是因为你没有遵循官方指南中推荐的验证方法放置顺序。
解决方案:
为了确保正确的执行顺序,请遵循以下准则:
- 将带有 per=true 的验证器放在验证方法定义的开头。
- 遵循此顺序: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 参数:如何确保验证方法的正确执行顺序?的详细内容,更多请关注php中文网其它相关文章!