
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)。










