0

0

Pydantic 别名技巧:将现有字段别名指向嵌套键值

霞舞

霞舞

发布时间:2025-10-10 10:07:18

|

743人浏览过

|

来源于php中文网

原创

pydantic 别名技巧:将现有字段别名指向嵌套键值

本文旨在解决在使用 Pydantic 处理遗留 API 数据时,如何将响应中的嵌套字段值映射到现有字段的问题。通过 computed_field 和 Field(exclude=True) 的组合,以及 serialization_alias 和 validation_alias 属性与 AliasPath 的结合使用,可以优雅地实现字段别名,避免手动删除原始字段,并保持数据模型的清晰和简洁。

在使用 Pydantic 处理来自遗留 API 的数据时,经常会遇到响应字段结构不符合预期的情况。一个常见的场景是,需要将响应中的嵌套字段的值映射到模型中已存在的字段上,而不是保留原始的嵌套结构。本文将介绍两种使用 Pydantic 实现这种字段别名的方法,并提供示例代码。

方法一:使用 computed_field 和 Field(exclude=True)

这种方法适用于 Pydantic v1.0 及以上版本。其核心思想是,首先将原始嵌套字段定义为一个 Pydantic 模型,然后使用 computed_field 创建一个计算字段,该字段从嵌套模型中提取所需的值。同时,使用 Field(exclude=True) 将原始嵌套字段排除在序列化结果之外。

以下是一个示例:

from pydantic import BaseModel, Field, computed_field

class Logo(BaseModel):
    url: str = ''


class Survey(BaseModel):
    logo: Logo = Field(exclude=True)

    @computed_field
    @property
    def logo_url(self) -> str:
        return self.logo.url

a = Survey(logo={'url': 'foo'})
print(a.model_dump())
#{'logo_url': 'foo'}

在这个例子中,Logo 模型表示 API 响应中的 logo 字段,它包含一个 url 属性。Survey 模型包含一个 logo 字段,类型为 Logo,并且使用 exclude=True 排除在序列化结果之外。logo_url 是一个计算字段,它使用 @computed_field 装饰器标记,并使用 @property 定义为属性。logo_url 属性从 logo 字段的 url 属性中提取值。

优点:

  • 实现简单,易于理解。
  • 不需要修改原始 API 响应数据。

缺点:

  • 需要定义额外的 Logo 模型。
  • logo 字段仍然存在于模型实例中,只是在序列化时被排除。

方法二:使用 serialization_alias 和 validation_alias 以及 AliasPath

这种方法适用于 Pydantic v2.0 及以上版本,使用了 serialization_alias 和 validation_alias 属性,以及 AliasPath。serialization_alias 用于指定序列化时使用的字段名,validation_alias 用于指定验证时使用的字段名。AliasPath 用于指定嵌套字段的路径。

Simplified
Simplified

AI写作、平面设计、编辑视频和发布内容。专为团队打造。

下载

以下是一个示例:

from pydantic import BaseModel, Field, AliasPath

class Survey(BaseModel):
    logo_url: str = Field(
        ...,
        serialization_alias="logo",
        validation_alias=AliasPath('logo', 'url')
    )

a = Survey.model_validate({'logo': {'url': 'foo'}})
print(a.model_dump(by_alias=True))
# {'logo': 'foo'}

在这个例子中,logo_url 字段使用了 serialization_alias="logo",这意味着在序列化时,该字段将被命名为 logo。validation_alias=AliasPath('logo', 'url') 指定了验证时,logo_url 字段的值应该从 logo 字典的 url 键中获取。

优点:

  • 代码更加简洁。
  • 不需要定义额外的模型。
  • 可以直接将嵌套字段的值映射到目标字段。

缺点:

  • 需要理解 serialization_alias 和 validation_alias 的含义。
  • 只适用于 Pydantic v2.0 及以上版本。

总结

本文介绍了两种使用 Pydantic 将现有字段别名指向嵌套键值的方法。第一种方法使用 computed_field 和 Field(exclude=True),适用于 Pydantic v1.0 及以上版本。第二种方法使用 serialization_alias 和 validation_alias 以及 AliasPath,适用于 Pydantic v2.0 及以上版本。选择哪种方法取决于您的具体需求和 Pydantic 版本。在实际应用中,建议根据 API 响应的结构和复杂度,选择最合适的方法来实现字段别名。

注意事项:

  • 在使用 serialization_alias 时,需要确保在调用 model_dump() 方法时,设置 by_alias=True,才能使别名生效。
  • 在使用 validation_alias 时,需要确保使用 model_validate() 方法来验证数据,才能使别名生效。
  • 在处理复杂的嵌套结构时,可以组合使用 AliasPath 和其他 Pydantic 功能,例如 validator,来实现更灵活的字段别名。

相关专题

更多
云朵浏览器入口合集
云朵浏览器入口合集

本专题整合了云朵浏览器入口合集,阅读专题下面的文章了解更多详细地址。

0

2026.01.20

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

20

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

62

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

87

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

19

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

160

2026.01.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 4万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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