当前位置: 首页 > news >正文

TypedDict 解析

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

    from typing import TypedDictclass Movie(TypedDict):title: stryear: intdirector: strdef 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 TypedDictclass AppConfig(TypedDict):host: strport: intdebug: boolconfig: AppConfig = {"host": "localhost","port": 8080,"debug": True
}

2. API 数据解析

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

from typing import TypedDict, Listclass User(TypedDict):id: intname: stremail: strclass ApiResponse(TypedDict):users: List[User]total: intresponse: 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 TypedDictclass UserRecord(TypedDict):id: intname: stremail: strdef 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, Optionalclass RegistrationForm(TypedDict):username: strpassword: stremail: 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, Optionalclass Movie(TypedDict):title: stryear: intdirector: Optional[str]movie_example: Movie = {"title": "Inception","year": 2010,"director": "Christopher Nolan"
}# 如果尝试赋值错误类型的值,类型检查工具(如 mypy)会报错
# movie_example["year"] = "2010"  # 错误: year 应该是 int 类型

结论

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

结论

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

相关文章:

TypedDict 解析

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

Windows11和Ubuntu22双系统安装指南

一、需求描述 台式机电脑,已有Windows11操作系统,想要安装Ubuntu22系统(版本任意)。其中Windows安装在Nvme固态上,Ubuntu安装在Sata固态上,双盘双系统。开机时使用Grub控制进入哪个系统,效果图…...

Dockerfile-php7.4.33

# 使用一个包含基本编译工具的基础镜像 FROM ubuntu:latestRUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \echo "Asia/Shanghai" > /etc/timezone# 更新包列表并安装必要的编译工具和库 RUN apt-get update && apt-get i…...

如何降低MCU系统功耗?

大家在做MCU系统开发的时候,是否也碰到过降低MCU系统功耗的需求? MCU系统整板功耗是个综合的数据,包括MCU功耗以及外部器件功耗,在此我们主要介绍如何降低MCU的功耗: 可以在满足应用的前提下,降低MCU的运…...

移动端 UI 风格,诠释精致

移动端 UI 风格,诠释精致...

【408考点之数据结构】数组和特殊矩阵的压缩存储

数组和特殊矩阵的压缩存储 在数据结构中,数组是一种基础的数据结构,用于存储相同类型的元素的集合。矩阵则是一个二维数组,常用于表示图像、图形以及数学运算中的系数。随着矩阵的广泛应用,一些特殊类型的矩阵也被引入并得到了有…...

26、matlab多项式曲线拟合:polyfit ()函数

1、前言 在 MATLAB 中,可以使用 polyfit() 函数进行多项式曲线拟合。polyfit() 函数可以拟合一个多项式模型到给定的数据点,从而找到最符合这些数据点的多项式曲线。以下是关于 polyfit() 函数的一些基本说明和示例用法: 语法 p = polyfit(x, y, n) x 和 y 是数据点的横纵…...

VMR,支持30+种编程语言的SDK版本管理器,支持Windows/MacOS/Linux。

官方文档地址:https://docs.vmr.us.kg/ 欢迎安装使用,分享转发,前往github star。 跨平台,支持Windows,Linux,MacOS支持多种语言和工具,省心受到lazygit的启发,拥有更友好的TUI&…...

模板初阶【C++】

文章目录 模板的作用模板的原理模板分为两大类——函数模板和类模板函数模板语法函数模板实例化模板函数的方式模板函数的类型转换既有函数模板又有已经实现的函数,会优先调用哪一个? 类模板语法模板类实例化对象模板类的模板参数可以有缺省值类模板中的…...

搭建Vue的环境

目录 # 开篇 步骤一,准备Vue 的环境 步骤二,下载Vue.js的包 步骤三,创建并打开写前端代码的文件夹 步骤四,在VSCode中引入Vue.js的包 步骤五,创建第一个vue.html Vue其他知识 Vue.config命令 # 开篇 介绍&…...

[学习笔记]-MyBatis-Plus简介

简介 Mybatis-Plus(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。 简言之就是对单表的增删改查有了很好的封装。基本不用再单独写sql语句了。目前此类…...

2024.6.23 刷题总结

2024.6.23 **每日一题** 520.检测大写字母,本题是简单模拟题,考察了ASCLL码相关的知识,根据题意,本题对于字符串有三种正确的用法,所以我们分三类来讨论,先根据首字母的大小写来分类,如果首字母…...

mysql查询不同用户(操作记录)的最新一条记录

先用MAX(time) 和 group by item_id 查询出不同的item_id对应的最大时间,然后再在外面连表查询,查询 表中 item_id 和login_time 时间 相等于刚才的查询记录的记录 具体语句如下 select a.* from reyo a join (select item_id,max(login_time) as ti…...

Java中如何使用设计模式来解决编程问题?

Java中使用设计模式来解决编程问题,可以显著提高代码的可复用性、可维护性和可读性。设计模式是一套被广泛应用于软件工程的解决方案,描述了在特定上下文中面对具体问题时的可复用解决方案。以下是几种常用的设计模式及其应用场景: 单例模式…...

单机、集群和分布式

目录 1.概述 2.单机服务器 单机版的服务器的性能,设计上的瓶颈? 3.集群 解决瓶颈1: 没有解决瓶颈2: 没有解决瓶颈3: 集群的优点? 集群的缺点? 4.分布式 分布式的优点? 分…...

qt开发-10_LineEdit

QLineEdit 小部件是一个单行文本编辑器。行编辑允许用户使用一组有用的编辑函数输入和 编辑一行纯文本。包括撤消和重做、剪切和粘贴以及拖放。通过更改行编辑的 echoMode(),它 还可以用作“只写”字段,用于输入如密码等. 创建好项目后,进入 …...

福昕PDF编辑器快速去除PDF水印方法

在福昕PDF编辑器软件中打开一个带有水印的PDF文件,点击如图下所示的页面管理->水印,点击全部移除 点击 是 水印消除(注:部分类型的水印可以消除,但是有些类型的水印无法通过此方法消除)...

Cloudflare 常用操作

一、域名托管到cloudflare 登录cloudflare->添加站点->填写域名(例如阿里云)->继续选择free套餐->继续->保存cloudflare分配的DNS地址->进入阿里云域名管理->进入DNS管理/DNS修改把DNS地址修改为cloudflare分配的两个DNS->保存->回到cloudflare->…...

elementUI的table使用展开功能( type=“expand“ ),展开时合起上一次展开的内容,始终保持展开内容为一个,并且再次点击合起自身

直接上代码了没什么可讲的,主要是用到 row-key"id" :expand-row-keys"expands row-click"handleRowClick" <template><div class"ele-body"><el-card shadow"never"><!-- 数据表格 --><ele-pro-t…...

【金】?Y? python网页前端streamlit

1、如何从 Google Colab Notebook 启动 streamit参考-How to Launch Streamlit App from Google Colab Notebook !streamlit run web.py & npx localtunnel --port 8501 & curl ipv4.icanhazip.com...

数据仓库之Lambda架构

Lambda架构是一种设计大规模数据处理系统的架构模式&#xff0c;它结合了批处理和实时处理的优点&#xff0c;以应对大数据的多样性、速度和规模问题。该架构主要由三个层次组成&#xff1a;批处理层&#xff08;Batch Layer&#xff09;、速度层&#xff08;Speed Layer&#…...

Apriori 处理ALLElectronics事务数据

通过Apriori算法挖掘以下事务集合的频繁项集&#xff1a; 流程图 代码 # 导入必要的库 from itertools import combinations# 定义Apriori算法函数 def apriori(transactions, min_support, min_confidence):# 遍历数据&#xff0c;统计每个项的支持度 item_support {}for tr…...

Content Provider:深入解析Android数据共享的核心组件

在Android开发中&#xff0c;Content Provider是一个重要的组件&#xff0c;它允许应用程序之间共享数据。它扮演着“数据访问中间层”的角色&#xff0c;为不同应用程序提供了一个统一的数据访问接口。以下将从技术难点、面试官关注点、回答吸引力以及代码举例四个方面&#x…...

069、Python 函数的递归调用

函数可以自己调用自己吗&#xff1f;&#xff1f;&#xff1f; 这就涉及函数的递归的用法了。 递归的概念&#xff1a; 函数递归是指函数在其定义中直接或间接调用自身的过程。 递归是一种强有力的编程技术&#xff0c;通常用于解决可以被分解为相同问题的子问题的情况&…...

数仓开发那些事_番外

一位神州的正式员工&#xff08;没错&#xff0c;就是之前文章中出现的实习生&#xff09;&#xff1a;一闪&#xff0c;你今年涨工资了吗&#xff1f; 一闪&#xff1a;mad&#xff0c;一年辛苦到头只涨了500米 神州员工&#xff1a;你去年绩效不是优秀吗&#xff0c;怎么就涨…...

Vue3+TypeScript项目实战——打造雨雪交加的智慧城市

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 ⚡开源项目&#xff1a; rich-vue3 &#xff08;基于 Vue3 TS Pinia Element Plus Spring全家桶 MySQL&#xff09; &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;正逐渐往全干发展 &#x1…...

经典游戏案例:植物大战僵尸

学习目标&#xff1a;植物大战僵尸核心玩法实现 游戏画面 项目结构目录 部分核心代码 using System; using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.SceneManagement; using Random UnityEngine.Random;public enum Z…...

Go 与 Java 字符编码选择:UTF-8 与 UTF-16 的较量

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…...

vscode+picgo+gitee实现Markdown图床

vscode中编辑Markdown文件&#xff0c;复制的图片默认是保存在本地的。当文档上传csdn时&#xff0c;会提示图片无法识别 可以在gitee上创建图床仓库&#xff0c;使用picgo工具上传图片&#xff0c;在Markdown中插入gitee链接的方式来解决该问题。 一、 安装picgo工具 1.1 v…...

【thinkphp问题栏】tp5.0分页技巧

一、调用内置方法paginate thinkphp内置了一个paginate方法支持分页功能 该方法位于library\think\db\Query.php内 /*** 分页查询* param int|array $listRows 每页数量 数组表示配置参数* param int|bool $simple 是否简洁模式或者总记录数* param array $config 配…...

百事通网做网站/湖南最新消息今天

---查询表的更新时间 SELECT TABLE_NAME, UPDATE_TIME ,TABLE_COMMENT FROM information_schema.TABLES WHERE information_schema.TABLES.TABLE_SCHEMA city...

群晖 wordpress端口/赛雷猴是什么意思

对于数据分析&#xff0c;有一句话说的非常好&#xff1a;spss/sql之类的软件、决策树、时间序列之类的方法&#xff0c;这些仅仅就都是个工具而已&#xff0c;最重要的是对业务的把握。没有正确的业务理解&#xff0c;再牛的理论&#xff0c;再牛的工具&#xff0c;都是白搭。…...

wordpress全图水印插件/免费留电话号码的广告

java 向服务器段发报文。简单写了一个&#xff0c;只是验证一下数据流互相传送&#xff0c;具体功能可以自己加test.java 客户端&#xff1a;读取1.xml文件发送给DataServer(servlet),读取servlet返回的内容DataServer.java 服务器servlet:读取test发送的xml内容&#xff0c;把…...

杭州市建设委员会网站/北京优化互联网公司

ES.7: Keep common and local names short, and keep uncommon and non-local names longerES.7: 通用和局部的名称应该简短&#xff0c;特殊和非局部的名称应该较长。Reason(原因)Readability. Lowering the chance of clashes between unrelated non-local names.可读性。避免…...

cq网络网站/南京网络建站公司

Java程序员应该掌握哪些能力才能算是脱离菜鸟达到熟练的程度?1、语法&#xff1a;Java程序员必须比较熟悉语法&#xff0c;在写代码的时候IDE的编辑器对某一行报错应该能够根据报错信息 知道是什么样的语法错误并且知道任何修正。2、命令&#xff1a;必须熟悉JDK带的一些常用命…...

网站设计制作步骤/广点通投放平台

action 在 store 文件夹 里创建 actions 文件夹 使用函数来创建 action&#xff0c;通过传参把不一样的数据传递过去就好了&#xff0c;我们把这个创建 action 的函数叫做 actionCreator 返回一个 action 对象 export const increment (payload) > ({type: INCREMENT,pa…...