自定义验证器示列

要在Pydantic模型中限制phone字段只接受数字,可以通过自定义验证器来实现。User类包含一个自定义验证器函数,该函数会检查phone字段是否全为数字:

python 复制代码
from pydantic import BaseModel, EmailStr, Field, validator

class User(BaseModel):
    name: str = Field(..., min_length=1, max_length=10)
    age: int = Field(..., ge=0, le=200)
    email: EmailStr
    phone: str = Field(default="13800138000", min_length=11, max_length=11)

    @validator('phone')
    def phone_must_be_digits(cls, value):
        # 检查phone字段是否全部由数字组成
        if not value.isdigit():
            raise ValueError("Phone number must contain only digits.")
        return value

# 测试用例
try:
    user = User(name="Tom", age=22, email="alice@example.com", phone='1380013800e')
    data = user.model_dump()
    print("data:",data)
except ValueError as e:
    print("error:",e)  # 这里会打印出错误信息,因为phone字段包含了非数字字符


# 正确用例
try:
    valid_user = User(name="Tom", age=22, email="alice@example.com", phone='13800138000')
    valid_data = valid_user.model_dump()
    print("valid_data:",valid_data)
except ValueError as e:
    print("e:",e)

添加了一个名为phone_must_be_digits的验证器装饰器到phone字段。这个验证器会检查字段值是否全为数字,如果不是,则抛出一个ValueError异常。这样,在尝试创建一个User实例时,如果phone字段包含了非数字字符,就会立即得到反馈。

运行结果如下:

python 复制代码
  @validator('phone')
error: 1 validation error for User
phone
  Value error, Phone number must contain only digits. [type=value_error, input_value='1380013800e', input_type=str]
    For further information visit https://errors.pydantic.dev/2.5/v/value_error
valid_data: {'name': 'Tom', 'age': 22, 'email': 'alice@example.com', 'phone': '13800138000'}
相关推荐
dangfulin20 小时前
fastapi+sqlalchemy实现一对一、一对多、多对多关系数据操作
fastapi
龙腾AI白云1 天前
【基于Transformer的人工智能模型搭建与fine-tuning】
scikit-learn·fastapi
叼奶嘴的超人2 天前
手动创建Docker版Fastapi CI/CD镜像文件
ci/cd·docker·fastapi
regret~2 天前
【笔记】Ant Design+FastAPI 项目 Linux 服务器内网部署完整笔记
服务器·笔记·fastapi
regret~2 天前
【笔记】Ant Design(含Umi Max)+FastAPI 内网部署&接口代理 核心笔记
笔记·fastapi
全栈测试笔记3 天前
FastAPI系列(12):响应模型参数
开发语言·python·fastapi
叼奶嘴的超人3 天前
Fastapi之UV安装方式与使用方式
fastapi·uv
强化试剂瓶4 天前
Silane-PEG8-DBCO,硅烷-聚乙二醇8-二苯并环辛炔技术应用全解析
python·flask·numpy·pyqt·fastapi
曲幽4 天前
FastAPI日志实战:从踩坑到优雅配置,让你的应用会“说话”
python·logging·fastapi·web·error·log·info
布局呆星4 天前
FastAPI:高性能Python Web框架
fastapi