TypedDict 解析

news2024/10/7 4:22:26

TypedDict 解析



文章目录

  • TypedDict 解析
      • 1. 类型安全性
      • 2. 可读性
      • 3. 可维护性
      • `TypedDict` 的解决方案
      • 没有 `TypedDict` 会发生什么?
      • 使用 `TypedDict` 的优势
    • `TypedDict` 应用场景
      • 1. 配置文件解析
      • 2. API 数据解析
      • 3. 数据库记录表示
      • 4. 表单数据验证
      • 5. 大型团队协作
      • 6. 静态类型检查
      • 结论
      • 结论


TypedDict 是 Python 3.8 引入的一种类型提示工具,旨在解决以下几个问题:

1. 类型安全性

传统的 Python 字典在使用时没有类型检查,容易出现类型错误。比如,一个字典可能包含不同类型的数据,如果不小心将错误类型的数据存入字典中,代码在运行时可能会崩溃,导致难以调试的问题。

2. 可读性

在没有明确类型定义的情况下,其他开发者需要通过阅读大量上下文代码才能理解字典的结构和预期用途。这不仅费时费力,还增加了误解的风险。

3. 可维护性

随着代码的复杂度增加,管理和维护没有明确结构的字典变得越来越困难,容易引入错误,特别是在大型项目中。

TypedDict 的解决方案

TypedDict 提供了一种方法来定义字典的结构,使得代码在类型检查时更安全和可读。通过明确声明字典中每个键的名称和类型,可以显著提高代码的可维护性和可读性。

没有 TypedDict 会发生什么?

如果没有 TypedDict,开发者通常会遇到以下问题:

  1. 类型不安全
    没有类型检查的字典容易导致类型错误。例如:

    movie_example = {
        "title": "Inception",
        "year": 2010,
        "director": "Christopher Nolan"
    }
    
    movie_example["year"] = "2010"  # 没有类型检查,可能导致运行时错误
    
  2. 难以理解的代码
    字典结构不明确,其他开发者需要通过阅读大量上下文代码才能理解字典的预期结构和用途。例如:

    def print_movie(movie):
        print(f"Title: {movie['title']}")
        print(f"Year: {movie['year']}")
        print(f"Director: {movie.get('director', 'Unknown')}")
    
    # 调用函数时需要确保字典结构正确
    movie_example = {
        "title": "Inception",
        "year": 2010,
        "director": "Christopher Nolan"
    }
    print_movie(movie_example)
    
  3. 难以维护
    随着项目规模增大,维护没有明确结构的字典变得越来越困难。任何对字典结构的修改都需要逐个检查相关代码,容易引入错误。

使用 TypedDict 的优势

  1. 类型安全性
    使用 TypedDict 可以显式地指定字典中每个键的类型,防止类型错误。

    from typing import TypedDict
    
    class Movie(TypedDict):
        title: str
        year: int
        director: str
    
    movie_example: Movie = {
        "title": "Inception",
        "year": 2010,
        "director": "Christopher Nolan"
    }
    
    # 如果尝试赋值错误类型的值,类型检查工具(如 mypy)会报错
    # movie_example["year"] = "2010"  # 错误: year 应该是 int 类型
    
  2. 可读性高
    TypedDict 提供的明确结构定义,使代码更具自文档性,其他开发者可以轻松理解字典的预期结构和用途。

    from typing import TypedDict
    
    class Movie(TypedDict):
        title: str
        year: int
        director: str
    
    def print_movie(movie: Movie):
        print(f"Title: {movie['title']}")
        print(f"Year: {movie['year']}")
        print(f"Director: {movie.get('director', 'Unknown')}")
    
    movie_example: Movie = {
        "title": "Inception",
        "year": 2010,
        "director": "Christopher Nolan"
    }
    print_movie(movie_example)
    
  3. 易于维护
    TypedDict 的类型定义约束使得字典结构更容易管理和维护,特别是在大型项目中。

  4. 实例
    pycharm中使用 TypedDict ,当字典出现错误的类型时,可以进行提示(在vscode中没有看到)。
    在这里插入图片描述

TypedDict 应用场景

1. 配置文件解析

如果你的应用需要读取和解析复杂的配置文件(例如 JSON 或 YAML 格式),可以使用 TypedDict 来定义配置文件的结构。这样可以确保在解析配置文件时,数据的类型是正确的,并且在使用配置数据时有明确的类型提示。

from typing import TypedDict

class AppConfig(TypedDict):
    host: str
    port: int
    debug: bool

config: AppConfig = {
    "host": "localhost",
    "port": 8080,
    "debug": True
}

2. API 数据解析

在处理外部 API 返回的数据时,使用 TypedDict 可以定义返回数据的结构,确保数据的类型和字段是正确的。这在处理复杂的 JSON 响应时尤为重要。

from typing import TypedDict, List

class User(TypedDict):
    id: int
    name: str
    email: str

class ApiResponse(TypedDict):
    users: List[User]
    total: int

response: ApiResponse = {
    "users": [
        {"id": 1, "name": "Alice", "email": "alice@example.com"},
        {"id": 2, "name": "Bob", "email": "bob@example.com"}
    ],
    "total": 2
}

3. 数据库记录表示

在处理数据库记录时,可以使用 TypedDict 来定义表结构。这不仅可以确保在查询数据库时返回的数据类型正确,还可以提高代码的可读性和可维护性。

from typing import TypedDict

class UserRecord(TypedDict):
    id: int
    name: str
    email: str

def get_user_by_id(user_id: int) -> UserRecord:
    # 假设我们从数据库中获取数据
    return {"id": user_id, "name": "Alice", "email": "alice@example.com"}

4. 表单数据验证

在处理 web 表单数据时,可以使用 TypedDict 来定义表单数据的结构,并在处理表单数据时进行类型检查。这有助于确保表单数据的类型正确,并且简化数据验证过程。

from typing import TypedDict, Optional

class RegistrationForm(TypedDict):
    username: str
    password: str
    email: Optional[str]

def process_registration_form(data: RegistrationForm):
    # 处理注册表单数据
    print(data["username"])
    print(data["password"])
    print(data.get("email"))

5. 大型团队协作

在大型团队协作开发中,使用 TypedDict 可以明确数据结构,减少沟通成本和误解,提高代码质量和可维护性。每个团队成员都可以轻松理解和使用 TypedDict 定义的数据结构。

6. 静态类型检查

使用 TypedDict 可以结合静态类型检查工具(如 mypy)进行类型检查,捕获潜在的类型错误,提高代码的可靠性和安全性。

from typing import TypedDict, Optional

class Movie(TypedDict):
    title: str
    year: int
    director: Optional[str]

movie_example: Movie = {
    "title": "Inception",
    "year": 2010,
    "director": "Christopher Nolan"
}

# 如果尝试赋值错误类型的值,类型检查工具(如 mypy)会报错
# movie_example["year"] = "2010"  # 错误: year 应该是 int 类型

结论

TypedDict 在需要明确定义数据结构的场景下非常有用,特别是在处理配置文件、API 数据、数据库记录、表单数据以及大型团队协作开发时。它通过提供类型安全性和明确的数据结构定义,提高了代码的可读性、可维护性和可靠性。

结论

TypedDict 是一种强大的工具,解决了传统字典缺乏类型安全性、可读性和可维护性的问题。通过明确定义字典的结构,TypedDict 提高了代码的安全性、可读性和可维护性,是现代 Python 开发中推荐的做法。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据可视化在智慧社区中的关键应用

数据可视化能够在智慧社区中发挥重要作用,通过直观和交互的方式将复杂的数据呈现出来,提升社区管理效率,优化居民生活体验,促进社区的可持续发展。在智慧社区中,数据可视化的应用涵盖了安全、环境、能源、交通和公共服…

AI播客下载:Eye on AI(AI深度洞察)

"Eye on A.I." 是一档双周播客节目,由长期担任《纽约时报》记者的 Craig S. Smith 主持。在每一集中,Craig 都会与在人工智能领域产生影响的人们交谈。该播客的目的是将渐进的进步置于更广阔的背景中,并考虑发展中的技术的全球影响…

【React】登录-封装Token的存取删方法--共享复用

在token.js中 // 封装存取方法const TOKENKEY token_keyfunction setToken (token) {return localStorage.setItem(TOKENKEY, token) }function getToken () {return localStorage.getItem(TOKENKEY) }function clearToken () {return localStorage.removeItem(TOKENKEY) }ex…

tensorRT C++使用pt转engine模型进行推理

目录 1. 前言2. 模型转换3. 修改Binding4. 修改后处理 1. 前言 本文不讲tensorRT的推理流程,因为这种文章很多,这里着重讲从标准yolov5的tensort推理代码(模型转pt->wts->engine)改造成TPH-yolov5(pt->onnx-…

微信小程序毕业设计-在线厨艺平台系统项目开发实战(附源码+论文)

大家好!我是程序猿老A,感谢您阅读本文,欢迎一键三连哦。 💞当前专栏:微信小程序毕业设计 精彩专栏推荐👇🏻👇🏻👇🏻 🎀 Python毕业设计…

XSS漏洞实验

本篇为xss漏洞实验练习,练习网址来源于网络 练习网址:XSS平台|CTF欢迎来到XSS挑战|XSS之旅|XSS测试 一、前置说明 在测试过程中,有哪些东西是我们可以利用来猜测与判断的: 网页页面的变化;审查网页元素;查…

奇瑞复活经典路虎!中国技术,英国车标,卖向全球

ChatGPT狂飙160天,世界已经不是之前的样子。 更多资源欢迎关注 6月19日,奇瑞和捷豹路虎宣布签署战略合作意向书,将复活“Freelander神行者”品牌。 小编当课代表,做个简单总结: 英国品牌,中国技术&#xf…

数组 (java)

文章目录 一维数组静态初始化动态初始化 二维数组静态初始化动态初始化 数组参数传递可变参数关于 main 方法的形参 argsArray 工具类sort 中的 comparable 和 comparatorcomparator 比较器排序comparable 自然排序 一维数组 线性结构 静态初始化 第一种:int[] a…

基于uni-app和图鸟UI开发上门服务小程序

一、技术栈选择 uni-app:我们选择了uni-app作为开发框架,因为它基于Vue.js,允许我们编写一次代码,发布到多个平台,包括iOS、Android、Web以及各种小程序。uni-app的丰富组件库、高效的状态管理以及便捷的预览调试功能&…

无霍尔BLDC驱动

目前主要的无霍尔控制方案是基于反电势检测信 息判断换相点,本文研究反电势在 PWM - OFF 点的检 测方案确定换相点。 1. 反电动势检测方案 BLDC 的模型做等效,将线圈阻抗看成是一个 线性电阻和一个储能电感的等效,其等效电路图如图 1所示。 电机三相绕组输出端电压的电压…

【PL理论深化】(3) MI 归纳法:归纳假设 (IH) | 结构归纳法 | 归纳假设的证明

💬 写在前面:所有编程语言都是通过归纳法定义的。因此,虽然编程语言本身是有限的,但用该语言编写的程序数量是没有限制的,本章将学习编程语言研究中最基本的归纳法。本章我们继续讲解归纳法,介绍归纳假设和…

issues.sonatype.org网站废弃,Maven仓库账号被废弃问题解决

问题起因: 今天自己的项目发布了一个新版本,打算通过GitHub流水线直接推送至Maven中央仓库,结果发现报错 401,说我的账号密码认证失败。我充满了疑惑我寻思难度我的号被盗掉了吗。于是我打开Nexus Repository Manager尝试登录账号…

最新下载:XmanagerXShell【软件附加安装教程】

​相信大家都认同支持IPv6:最近越来越多的公司和国家都采用了IPv6,Xmanager的最新版本v5也加入支持这个功能,无论你是同时使用IPv4和IPv6网络或者完全的IPv6网络,Xmanager 5都可完全满足你的要求,使用MIT Kerberos认证…

Vue41 ref属性

ref属性 ref是Vue提供的获取组件的属性 <template><div><h1 v-text"msg" ref"title"></h1><button ref"btn" click"showDOM">点我输出上方的DOM元素</button><MySchool ref"sch"…

Android开发神器:OkHttp框架源码解析

NetworkInterceptors CallServiceInterceptor 1.RealInterceptorChain.proceed() 2.EventListener.callStart()也是在RealCall.execute()嵌入到Request调用过程, EventListener.callEnd()位于StreamAllocation中调用 3.Request.Builder url (String/URL/HttpUrl) header …

WordPress插件:子比zibll主题插件 炙焰美化全开源插件V3.2

在数字时代&#xff0c;拥有一个美观且功能丰富的网站是吸引和保持用户的关键。WordPress作为全球最受欢迎的内容管理系统之一&#xff0c;提供了一个灵活的平台&#xff0c;让网站所有者能够通过插件来增强其网站的功能和外观。"炙焰美化全开源插件V3.2"正是这样一款…

SD卡无法读取?数据恢复全攻略!

SD卡无法读取问题描述 在日常使用电子设备时&#xff0c;我们有时会遇到SD卡无法读取的情况。当插入SD卡后&#xff0c;设备可能无法识别或访问其中的数据&#xff0c;这给我们带来了诸多不便。SD卡无法读取&#xff0c;意味着存储在卡中的重要文件、照片和视频等资料可能面临…

QListView、QTableView或QTreeView截取滚动区域(截长图)

本文以QTreeView为例,理论上继承自QAbstractScrollArea的类都支持本文所述的方法。 一.效果 一共5个文件夹,每个文件文件夹下有5个文件,先把文件夹展开,然后截图。将滚动条拖到居中位置,是为了证明截图对滚动条无影响 下面是截的图 二.原理 将滚动区域的viewport设置为…

Typora最新安装教程2024

Typora是一款广受好评的跨平台Markdown编辑软件&#xff0c;支持Windows、MacOS和Linux操作系统。它的设计旨在提供一个无干扰、高效且直观的写作环境。户快速管理和查找文档&#xff0c;支持直接在软件内浏览和操作文件结构。 Typora以其简洁而强大的功能集合&#xff0c;成为…

SQL Server中CROSS APPLY连接操作

在 SQL Server 中&#xff0c;CROSS APPLY 是一个连接操作&#xff0c;它类似于 INNER JOIN&#xff0c;但有一些关键差异&#xff0c;特别是在处理表值函数&#xff08;TVF&#xff09;、行集函数或子查询时。CROSS APPLY 返回对于外部查询中的每一行&#xff0c;在内部查询或…