搜索

Pydantic 模型导出时忽略额外字段

碧海醫心
发布: 2025-09-06 22:43:43
原创
516人浏览过

pydantic 模型导出时忽略额外字段

在 Pydantic 中,extra="allow" 配置允许模型接收未在字段定义中声明的额外数据。然而,在某些场景下,例如数据序列化或导出时,我们可能希望忽略这些额外字段,只保留模型定义中明确声明的字段。本文将介绍一种优雅的方法,通过自定义基础模型类和使用 model_serializer 装饰器,来实现这一目标。

使用 model_serializer 忽略 extra 字段

Pydantic 的 model_serializer 装饰器允许我们自定义模型的序列化行为。我们可以创建一个自定义的基础模型类,并在该类中使用 model_serializer 来过滤掉 extra 字段。

from typing import Any
from pydantic import BaseModel, ConfigDict, model_serializer, SerializerFunctionWrapHandler, FieldSerializationInfo


class MyBaseModel(BaseModel):
    @model_serializer(mode="wrap")
    def _serialize(self, handler):
        d = handler(self)
        d = {k:v for k, v in d.items() if k in self.model_fields}
        return d
登录后复制

在这个 MyBaseModel 类中,_serialize 方法被 model_serializer(mode="wrap") 装饰器修饰。mode="wrap" 表示我们将在 Pydantic 默认序列化逻辑的基础上进行修改。

_serialize 方法首先调用 handler(self) 来执行默认的序列化过程,得到一个字典 d。然后,我们使用字典推导式,只保留 d 中键存在于 self.model_fields 中的键值对。self.model_fields 是 Pydantic 提供的一个属性,包含了模型中所有声明的字段。

应用到实际模型

现在,我们可以将 MyBaseModel 作为我们所有模型的基类。

Brev AI
Brev AI

Brev.ai:搭载Suno AI V3.5技术的免费AI音乐生成器

Brev AI125
查看详情 Brev AI
class Nested(MyBaseModel):

    model_config = ConfigDict(extra="allow")

    baz: str


class Root(MyBaseModel):

    foo: int = 10
    bar: int
    nested: Nested
登录后复制

在这个例子中,Nested 和 Root 都继承自 MyBaseModel。这意味着它们在序列化时都会应用我们自定义的逻辑,忽略 extra 字段。

示例代码及验证

以下是完整的示例代码,展示了如何使用 MyBaseModel 来忽略 extra 字段。

from typing import Any
from pydantic import BaseModel, ConfigDict, model_serializer, SerializerFunctionWrapHandler, FieldSerializationInfo


class MyBaseModel(BaseModel):
    @model_serializer(mode="wrap")
    def _serialize(self, handler):
        d = handler(self)
        d = {k:v for k, v in d.items() if k in self.model_fields}
        return d


class Nested(MyBaseModel):

    model_config = ConfigDict(extra="allow")

    baz: str


class Root(MyBaseModel):

    foo: int = 10
    bar: int
    nested: Nested


if __name__ == "__main__":

    model = Root(foo=10, bar=20, nested={"baz": "boing", "extra": "so special"})

    dumped_data = model.model_dump()

    assert "extra" not in dumped_data["nested"]
登录后复制

运行这段代码,assert 语句将会通过,证明 dumped_data["nested"] 中不包含 extra 字段。

注意事项

  • 这种方法需要在所有需要忽略 extra 字段的模型中继承 MyBaseModel。
  • model_serializer 的 mode 参数有多种选择,wrap 模式是最常用的,因为它允许我们在默认序列化逻辑的基础上进行修改。

总结

通过自定义基础模型类和使用 model_serializer 装饰器,我们可以方便地控制 Pydantic 模型的序列化行为,忽略 extra 字段,从而简化代码并提高效率。这种方法尤其适用于处理包含多层嵌套和大量 extra 数据的复杂模型。

以上就是Pydantic 模型导出时忽略额外字段的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号