自定义验证器示列

要在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'}
相关推荐
Muyuan19987 小时前
22.让 RAG Agent 更像真实产品:聊天页面优化、PDF 上传、知识库重建与检索片段展示
python·django·pdf·fastapi
Muyuan19988 小时前
25.Paper RAG Agent 优化记录:上传反馈、计算器安全与 Chunk 参数调整
python·安全·django·sqlite·fastapi
Li emily9 小时前
港股api接入指南:实时行情与历史数据获取
python·api·fastapi
Li emily12 小时前
用Python批量调用外汇接口获取多货币汇率
人工智能·python·api·fastapi
Muyuan199812 小时前
26.Paper RAG Agent 展示面收口:截图与项目表达更新记录
人工智能·python·django·fastapi
li星野12 小时前
FastAPI 项目加入 WebSocket 支持
python·websocket·fastapi
紫小米13 小时前
FastAPI 与微服务架构
微服务·架构·fastapi
.柒宇.13 小时前
AI 掘金头条项目-新闻模块实现
数据库·后端·python·fastapi
AI木马人1 天前
1.人工智能实战:大模型推理接口响应慢?从模型加载到 FastAPI 部署的完整优化方案
人工智能·python·fastapi
.柒宇.1 天前
FastAPI 基础指南:从入门到实战
开发语言·python·fastapi