Pydantic模型继承解析:从字段继承到多态模型

news/2025/3/19 17:07:15/文章来源:https://www.cnblogs.com/Amd794/p/18781340

title: Pydantic模型继承解析:从字段继承到多态模型
date: 2025/3/19
updated: 2025/3/19
author: cmdragon

excerpt:
涵盖字段继承、属性覆盖、多态模型等关键机制。将掌握类型安全的继承体系构建方法,实现企业级数据校验方案,避免传统面向对象继承的常见陷阱。

categories:

  • 后端开发
  • FastAPI

tags:

  • Pydantic模型继承
  • 字段覆盖机制
  • 多态数据模型
  • 类型安全校验
  • 配置继承策略
  • 现代化数据建模
  • 校验错误处理

image

image

扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

探索数千个预构建的 AI 应用,开启你的下一个伟大创意

第一章:基础继承机制

1.1 简单继承模型

from pydantic import BaseModelclass UserBase(BaseModel):email: stris_active: bool = Trueclass UserCreate(UserBase):password: str  # 新增字段is_active: bool = False  # 覆盖父类默认值# 验证示例
user = UserCreate(email="test@example.com", password="secret")
print(user.is_active)  # 输出: False

继承规则

  • 子类自动获得父类所有字段
  • 字段默认值可被覆盖
  • 新增字段需明确声明

1.2 字段类型强化

from pydantic import Fieldclass StrictUser(UserBase):email: str = Field(..., regex=r"^[\w\.]+@[a-zA-Z]+\.[a-zA-Z]+$")age: int = Field(ge=18, lt=100)  # 新增约束字段

第二章:字段覆盖策略

2.1 默认值覆盖

class ConfigBase(BaseModel):timeout: int = 10retries: int = 3class ProductionConfig(ConfigBase):timeout: int = 30  # 覆盖默认值log_level: str = "ERROR"  # 新增字段

2.2 类型约束升级

class PaymentBase(BaseModel):amount: floatclass StrictPayment(PaymentBase):amount: confloat(gt=0)  # 强化类型约束

覆盖规则矩阵

父类字段定义 子类合法操作 非法操作
str 添加regex约束 更改为int类型
Optional[int] 改为int 改为str
float 添加ge/le约束 移除类型约束

第三章:多态模型实现

3.1 鉴别器字段

from pydantic import Fieldclass Animal(BaseModel):type: str = Field(..., alias="_type")class Cat(Animal):_type: str = "cat"lives: intclass Dog(Animal):_type: str = "dog"breed: strdef parse_animal(data: dict) -> Animal:type_map = {"cat": Cat,"dog": Dog}return type_map[data["_type"]](**data)

3.2 自动化模型解析

from pydantic import create_modelDynamicModel = create_model('DynamicModel',__base__=UserBase,role=(str, Field(regex="^(admin|user)$"))
)

第四章:配置继承体系

4.1 全局配置继承

class Parent(BaseModel):class Config:extra = "forbid"anystr_strip_whitespace = Trueclass Child(Parent):class Config(Parent.Config):validate_assignment = True

配置继承规则

  • 使用Config(Parent.Config)显式继承
  • 未指定时默认不继承父类配置
  • 支持多级配置覆盖

4.2 运行时配置修改

from pydantic import BaseModel, Extraclass FlexibleModel(BaseModel):class Config:extra = Extra.allowStrictModel = type('StrictModel',(FlexibleModel,),{'Config': type('Config', (FlexibleModel.Config,), {'extra': Extra.ignore})}
)

第五章:高级继承技巧

5.1 Mixin类设计

class TimestampMixin(BaseModel):created_at: datetime = Field(default_factory=datetime.now)updated_at: datetime = Field(default_factory=datetime.now)class UserWithTime(TimestampMixin, UserBase):pass

5.2 动态模型生成

def create_model_with_extra_fields(base: Type[BaseModel], **fields):return create_model(f'Extended{base.__name__}',__base__=base,**fields)ExtendedUser = create_model_with_extra_fields(UserBase,phone=(str, Field(regex=r"^1[3-9]\d{9}$"))
)

第六章:错误处理与调试

6.1 继承错误分析

try:class InvalidModel(UserBase):email: int  # 类型冲突
except TypeError as e:print(f"继承错误: {e}")

常见错误码

错误类型 触发场景 解决方案
ValidationError 字段类型不匹配 检查继承链中的类型定义
TypeError 不兼容字段覆盖 使用@validator处理转型逻辑
ConfigConflict 配置项冲突 显式指定配置继承关系

6.2 调试继承体系

def print_model_fields(model: Type[BaseModel]):for name, field in model.__fields__.items():print(f"{name}: {field.type_} (default={field.default})")print_model_fields(StrictPayment)

课后Quiz

Q1:如何实现字段默认值覆盖?
A) 在子类重新声明字段
B) 使用Field(default=...)
C) 修改父类定义

Q2:多态模型必须包含什么特征?

  1. 鉴别器字段
  2. 相同字段数量
  3. 统一校验规则

Q3:处理类型冲突的最佳方式?


错误解决方案速查表

错误信息 原因分析 解决方案
field type mismatch 子类字段类型与父类不兼容 使用Union类型或添加转型校验器
extra fields not permitted 未正确继承extra配置 显式继承父类Config
discriminator field missing 未定义多态鉴别器字段 添加带有别名_type的公共字段

扩展阅读

  1. 《Pydantic官方文档-模型继承》 - 官方标准实现规范
  2. 《类型系统设计模式》 - 企业级模型架构方案
  3. 《Python元编程实战》 - 动态模型生成技术

开发箴言:优秀的模型继承设计应遵循LSP(里氏替换原则),任何父类出现的地方都可以被子类替换。建议继承层级不超过3层,复杂场景优先选择组合模式而非深度继承。

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:Pydantic模型继承解析:从字段继承到多态模型 | cmdragon's Blog

往期文章归档:

  • FastAPI性能优化指南:参数解析与惰性加载 | cmdragon's Blog
  • FastAPI依赖注入:参数共享与逻辑复用 | cmdragon's Blog
  • FastAPI安全防护指南:构建坚不可摧的参数处理体系 | cmdragon's Blog
  • FastAPI复杂查询终极指南:告别if-else的现代化过滤架构 | cmdragon's Blog
  • FastAPI 核心机制:分页参数的实现与最佳实践 | cmdragon's Blog
  • FastAPI 错误处理与自定义错误消息完全指南:构建健壮的 API 应用 🛠️ | cmdragon's Blog
  • FastAPI 自定义参数验证器完全指南:从基础到高级实战 | cmdragon's Blog
  • FastAPI 参数别名与自动文档生成完全指南:从基础到高级实战 🚀 | cmdragon's Blog
  • FastAPI Cookie 和 Header 参数完全指南:从基础到高级实战 🚀 | cmdragon's Blog
  • FastAPI 表单参数与文件上传完全指南:从基础到高级实战 🚀 | cmdragon's Blog
  • FastAPI 请求体参数与 Pydantic 模型完全指南:从基础到嵌套模型实战 🚀 | cmdragon's Blog
  • FastAPI 查询参数完全指南:从基础到高级用法 🚀 | cmdragon's Blog
  • FastAPI 路径参数完全指南:从基础到高级校验实战 🚀 | cmdragon's Blog
  • FastAPI路由专家课:微服务架构下的路由艺术与工程实践 🌐 | cmdragon's Blog
  • FastAPI路由与请求处理进阶指南:解锁企业级API开发黑科技 🔥 | cmdragon's Blog
  • FastAPI路由与请求处理全解:手把手打造用户管理系统 🔌 | cmdragon's Blog
  • FastAPI极速入门:15分钟搭建你的首个智能API(附自动文档生成)🚀 | cmdragon's Blog
  • HTTP协议与RESTful API实战手册(终章):构建企业级API的九大秘籍 🔐 | cmdragon's Blog
  • HTTP协议与RESTful API实战手册(二):用披萨店故事说透API设计奥秘 🍕 | cmdragon's Blog
  • 从零构建你的第一个RESTful API:HTTP协议与API设计超图解指南 🌐 | cmdragon's Blog
  • Python异步编程进阶指南:破解高并发系统的七重封印 | cmdragon's Blog
  • Python异步编程终极指南:用协程与事件循环重构你的高并发系统 | cmdragon's Blog
  • Python类型提示完全指南:用类型安全重构你的代码,提升10倍开发效率 | cmdragon's Blog
  • 三大平台云数据库生态服务对决 | cmdragon's Blog
  • 分布式数据库解析 | cmdragon's Blog
  • 深入解析NoSQL数据库:从文档存储到图数据库的全场景实践 | cmdragon's Blog
  • 数据库审计与智能监控:从日志分析到异常检测 | cmdragon's Blog
  • 数据库加密全解析:从传输到存储的安全实践 | cmdragon's Blog
  • 数据库安全实战:访问控制与行级权限管理 | cmdragon's Blog
  • 数据库扩展之道:分区、分片与大表优化实战 | cmdragon's Blog
  • 查询优化:提升数据库性能的实用技巧 | cmdragon's Blog
  • 性能优化与调优:全面解析数据库索引 | cmdragon's Blog
  • 存储过程与触发器:提高数据库性能与安全性的利器 | cmdragon's Blog
  • 数据操作与事务:确保数据一致性的关键 | cmdragon's Blog

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/901599.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20242428 实验一《Python程序设计》实验报告

学号20242428《Python程序设计》实验一报告 课程:《Python程序设计》 班级: 2424 姓名: 虎岳 学号:20242428 实验教师:王志强 实验日期:2025年3月19日 必修/选修: 公选课 1.实验内容 1.熟悉Python开发环境; 2.练习Python运行、调试技能;(编写书中的程序,并进行调试…

记录一次PG数据库连接数超最大值问题

报错内容: nested exception is org.postgresql.util.PSQLException: FATAL: remaining connection slots are reserved for non-replication superuser connections排查手段 : SELECT COUNT(*) FROM pg_stat_activity; 查询活跃的连接 SHOW max_connections; 查询数…

StarRocks 升级注意事项

前段时间升级了生产环境的 StarRocks,从 3.3.3 升级到了 3.3.9,期间还是踩了不少坑所以在这里记录下。因为我们的集群使用的是存算分离的版本,也是使用官方提供的 operator 部署在 kubernetes 里的,所以没法按照官方的流程进入虚拟机手动启停对应的服务。 只能使用 operato…

Grafana 添加官方模板

Refer 官方的模板地址: https://grafana.com/grafana/dashboards/ 1.进入到dashboard页面 2.点击New->Import 3.输入想要导入模板的id或者url地址都行 比如你想导入模板url地址是:https://grafana.com/grafana/dashboards/14584-argocd/ 你就可以填写上面的url地址,也可…

05C++数据类型——教学(2)

四、 数据类型.转换 教学视频 1. 数据类型类型名 类型声明 解释说明整型 int -2147483648 到 2147483647 的范围的整数长整形 long long 比上面大很多很多,这里装不下,具体搜索字符型 char 赋值只能是一个字符,比如 A,必须用单引号,双表示字符串不是字符浮点型 float 也叫…

革新科技!通过EtherCAT与Profinet网关实现温湿度监控,医药设备领域的智能革命来临!

通过网关EtherCAT---Profinet 通讯实现温湿度监控项目背景 某医药企业制药设备采用 EtherCAT 作为主控制总线,负责高速设备控制。温湿度传感器、执行器等环境监控设备基于 Profinet 通讯。 为实现机器整体环境参数的实时采集与集中监控,需要在 EtherCAT 总线与 Profinet 网络…

grafana添加跳转的超链接

1.进入到你想设置链接的dashboard中 2.选中表格-》点击Edit->进入到table 3.找到右侧栏中的 Data links -》add link:输入title和url地址,点击save 4.点击右上角的“Save dashboard”按钮保存 此时,表格中的数据点击时,就可以跳转了。

数独游戏 | 数字益智游戏①

依托国产的 AI 豆包完成的网页端的数独益智游戏。前情概要 2025年03月19日,依托豆包设计了数独游戏,嵌入到我的博客,数字益智游戏,欢迎体验。 数独游戏数独游戏.sudoku-game-container { font-family: Arial, sans-serif; display: flex; flex-direction: column; align-it…

itext5生成多个PDF并合并

PDF批量生成并合并为1个PDF 单个生成/*** 根据id查询数据* @param id 数据id* @return*/private Map<String, String> queryEntityDataById(String id) {//根据id查询Box entity = BoxService.getById(id);Map<String, String> data = new HashMap<String, Stri…

docker 容器修改端口映射

目录查看容器信息查看容器的端口映射情况,在容器外执行查找要修改容器的容器Id全称修改要端口映射的容器的配置文件查看容器信息 docker ps -a查看容器的端口映射情况,在容器外执行 docker port 容器ID 或者 docker port 容器名称查找要修改容器的容器Id全称 docker inspect …

Allure的下载安装以及自动生成测试报告

一、下载Allure压缩包 访问此链接:https://repo.maven.apache.org/maven2/io/qameta/allure/allure-commandline/ 根据你个人的需求,下载对应的allure版本即可,哪个兼容就下载哪个,需要哪个下载哪个。 比如,小编自己就随便下载了一个版本 下载完成之后,将下载好的安装包解…

referrerpolicy-以最小的成本实现系统的图片上传

背景 系统上传图片一般有以下三种方案:购买云存储(比如 AWS S3、阿里云 OSS、腾讯云 COS),获取图片URL 直接将图片上传到服务器,存储在本地作为静态资源 使用第三方的图片服务(比如有道、博客园),借用对方资源结合本系统需求:自建博客尽可能减少预算,方案1放弃;方案…