自定义验证器示列

要在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'}
相关推荐
Shi_haoliu13 小时前
python安装操作流程-FastAPI + PostgreSQL简单流程
python·postgresql·fastapi
曲幽16 小时前
FastAPI不止于API:手把手教你用Jinja2打造动态Web页面
python·fastapi·backend·jinja2·full stack·template engine·web development
PD我是你的真爱粉18 小时前
FastAPI中间件与路由
中间件·fastapi
闲人编程2 天前
使用FastAPI和WebSocket构建高性能实时聊天系统
websocket·网络协议·网络编程·fastapi·持久化·实时聊天·codecapsule
失忆爆表症2 天前
01_项目搭建指南:从零开始的 Windows 开发环境配置
windows·postgresql·fastapi·milvus
PD我是你的真爱粉2 天前
FastAPI使用tortoiseORM
数据库·fastapi
玄同7653 天前
Python 后端三剑客:FastAPI/Flask/Django 对比与 LLM 开发选型指南
人工智能·python·机器学习·自然语言处理·django·flask·fastapi
张3蜂4 天前
Python 四大 Web 框架对比解析:FastAPI、Django、Flask 与 Tornado
前端·python·fastapi
雪碧聊技术4 天前
ORM简介、安装、使用流程
fastapi·orm·基础代码编写
曲幽4 天前
FastAPI实战:用懒加载与Lifespan优雅管理重型依赖
fastapi·async·lifespan·lazy loading·startup event