FastAPI中Pydantic的用法

一、Pydantic 的 BaseModel 核心价值

Pydantic 的 BaseModel 是 Python 类型注解驱动的数据验证和序列化工具,核心解决以下问题


1. 数据验证自动化
  • 传统痛点:手动编写 if-else 校验逻辑,代码冗余且易出错

  • BaseModel 方案:通过类型注解自动验证字段类型、格式和约束

from pydantic import BaseModel, EmailStr, conint

class User(BaseModel):
    name: str                    # 必须为字符串类型
    email: EmailStr              # 自动验证邮箱格式
    age: conint(gt=0, lt=150)    # 必须为 1-149 的整数

2. 类型强制转换
  • 传统痛点:HTTP 请求参数(如字符串 "42")需手动转换为 int

  • BaseModel 方案:自动执行类型转换

class Item(BaseModel):
    id: int
    price: float

# 输入 {"id": "123", "price": "99.9"} 会被自动转换为:
# Item(id=123, price=99.9)

3. 序列化与反序列化
  • 传统痛点:ORM 对象无法直接转为 JSON,需手动处理

  • BaseModel 方案通过 .dict().json() 方法快速序列化

user = User(name="Alice", email="alice@example.com", age=30)
print(user.dict())  # 输出: {'name': 'Alice', 'email': 'alice@example.com', 'age': 30}

4. API 文档自动生成
  • 传统痛点:需手动维护 Swagger 文档,容易与实际代码不一致

  • BaseModel 方案FastAPI 自动提取模型结构生成交互式文档

from fastapi import FastAPI

app = FastAPI()

@app.post("/users")
def create_user(user: User):  # 自动生成 Swagger 文档中的 Request Body Schema
    return user

二、关键用法示例

1. 基础模型定义
from pydantic import BaseModel

class Book(BaseModel):
    title: str
    author: str
    year: int
    is_published: bool = False  # 带默认值的可选字段

2. 复杂数据校验
from pydantic import BaseModel, field_validator

class Product(BaseModel):
    sku: str
    price: float

    @field_validator("sku")
    def sku_must_be_uppercase(cls, v):
        if not v.isupper():
            raise ValueError("SKU 必须全大写")
        return v

    @field_validator("price")
    def price_must_be_positive(cls, v):
        if v <= 0:
            raise ValueError("价格必须大于 0")
        return v

3. 嵌套模型
class Address(BaseModel):
    street: str
    city: str

class Company(BaseModel):
    name: str
    address: Address  # 嵌套模型

# 使用示例
data = {
    "name": "Tech Corp",
    "address": {
        "street": "Main St",
        "city": "New York"
    }
}
company = Company(**data)

4. 与 ORM 对象互转(需配置 orm_mode
class UserBase(BaseModel):
    class Config:
        from_attributes = True  # 旧版本用 orm_mode = True

class UserCreate(UserBase):
    email: str
    password: str

# 从 SQLAlchemy 模型转换
db_user = UserORM(email="test@example.com", password_hash="...")
user = UserCreate.model_validate(db_user)  # 自动提取匹配字段

三、对比传统方案的优势

场景传统方法Pydantic BaseModel
数据验证手动编写校验函数声明式类型注解自动验证
错误处理分散的 try-except集中抛出 ValidationError 包含所有错误详情
文档维护手动编写接口文档自动生成 OpenAPI/Swagger 文档
类型转换显式调用 int()/str() 转换根据注解自动转换
嵌套数据结构多层字典手动解析通过嵌套模型自动验证和结构化

四、最佳实践建议

  1. 分层定义模型

    • 区分 Request Schema (输入) 和 Response Schema (输出)

    class UserCreate(BaseModel):  # 输入模型(包含密码)
        email: str
        password: str
    
    class UserResponse(BaseModel):  # 输出模型(排除敏感字段)
        id: int
        email: str
    
  2. 复用模型配置

    class ConfigMixin:
        from_attributes = True  # 启用 ORM 兼容模式
    
    class UserResponse(BaseModel):
        id: int
        email: str
        class Config(ConfigMixin):
            pass
    
  3. 组合复杂校验

    from pydantic import Field
    
    class Task(BaseModel):
        title: str = Field(..., min_length=3, max_length=100)
        priority: int = Field(gt=0, le=3, description="1-低, 2-中, 3-高")
    

通过 Pydantic 的 BaseModel,开发者可以大幅减少样板代码,同时获得类型安全、自动验证和清晰的文档化接口,是构建健壮 API 的核心工具。

FastAPI是一个现代、快速(高性能)的Web框架,用于构建API。它基于Python 3.7+的类型提示和异步支持,提供了简单易用的API开发体验。FastAPI具有以下特点: 1. 快速:FastAPI使用基于Starlette的异步请求处理器,可以处理大量并发请求,并具有出色的性能。 2. 类型提示:FastAPI使用Python的类型提示功能,可以在编译时进行类型检查,并提供自动生成API文档的功能。 3. 自动文档生成:FastAPI可以根据代码中的类型提示和注释自动生成交互式API文档,包括请求和响应模型、参数验证等。 4. 异步支持:FastAPI完全支持异步编程,可以使用async/await语法编写异步代码,提高性能和并发处理能力。 5. 安全性:FastAPI内置了常见的安全功能,如身份验证、授权等,并提供了易于使用的方式来保护API。 6. 数据验证:FastAPI使用Pydantic库进行数据验证和转换,可以自动解析请求数据,并进行类型检查和转换。 7. WebSocket支持:FastAPI支持WebSocket协议,可以轻松地构建实时应用程序。 Pydantic是一个用于数据验证和解析的Python库,它与FastAPI紧密集成。Pydantic提供了一种声明性的方式来定义数据模型,可以自动进行数据验证、类型转换和文档生成。Pydantic具有以下特点: 1. 声明性:Pydantic使用Python的类型提示来定义数据模型,可以在编译时进行类型检查,并提供自动生成文档的功能。 2. 数据验证:Pydantic可以自动验证输入数据的类型、长度、格式等,并提供友好的错误提示。 3. 数据转换:Pydantic可以自动将输入数据转换为指定的类型,如字符串转整数、字符串转日期等。 4. 文档生成:Pydantic可以根据数据模型自动生成文档,包括字段说明、类型信息等。 5. 序列化和反序列化:Pydantic提供了方便的方法来将数据模型转换为JSON、XML等格式,并支持从这些格式解析数据模型。 总结起来,FastAPI是一个快速、现代化的Web框架,而Pydantic是一个用于数据验证和解析的库。它们可以一起使用,提供了简单易用的API开发体验,并自动生成交互式API文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值