前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python类型标注入门与初探

Python类型标注入门与初探

作者头像
活用数据
发布2022-10-04 20:18:56
5720
发布2022-10-04 20:18:56
举报
文章被收录于专栏:数据医生专栏数据医生专栏

本文主要介绍Python中类型标注的作用,以及最常用的类型标注应该怎么写。

由于Python属于动态类型语言,所以只有在运行代码的时候才能够知道变量类型,而这往往会让我们在调用其他人的代码,或者自己很久以前(昨天)写的代码时传入错误的变量类型,导致bug产生。

所以在Python3.5的时候开始引入了类型标注(Type Hint),让我们能够显式地标注变量类型。

类型标注的优点

下面就是一个简单的带有类型标注的函数:

进行类型标注之后,有什么优点呢?

  1. 函数的可读性会增强。
  2. 使用这个函数时,IDE会显示这个函数的输入参数跟输出值是什么类型。
  3. 能帮我们解决一些由类型导致的逻辑问题,不用运行代码时就能够对代码进行分析。

静态分析工具mypy

不用运行代码时就能够对代码进行分析的工具,我们称为静态分析工具,这里介绍的是mypy

要使用mypy之前,需要先通过pip进行安装:

代码语言:javascript
复制
pip install mypy

安装好之后有以下两种使用方法。

方法一 在命令行中输入命令对文件进行检查

代码语言:javascript
复制
mypy example.py

方法二 在vscode中直接启用mypy检查

打开“settings.json”文件,增加下面这行设置:

代码语言:javascript
复制
"python.linting.mypyEnabled": true,

修改完之后再返回代码编辑,可以发现直接在编辑过程中就能显示错误了:

自定义数据类型的类型标注

Python的内置数据类型都是可以拿来做类型标注的,例入intfloatlist等等。

这里不做赘述,主要介绍自定义数据类型应该如何处理。

可以看到,在第9行函数的输入是类本身的时候是会报错的,而第10行的时候函数的输入类的实例化对象是没有任何问题的。

下面再介绍一种特殊情况,就是在类的方法里面需要用到这个类的类型的时候,但是这个类在写这个方法时还没有被定义,也就是遇到了“先有鸡还是先有蛋”的问题,这样写是会报错的:

这种情况下可以在Node加上双引号,把他变成String,就能解决循环依赖的问题:

列表类型标注

在很多场景下,我们不仅要求参数类型是list,还要求list内的对象是int类型,那么可以这样写:

代码语言:javascript
复制
from typing import List


def my_sum(lst: List[int]) -> int:
    total = 0
    for i in lst:
        total += i
    return total

对于Python3.9及更新版本,可以这样写:

代码语言:javascript
复制
def my_sum(lst: list[int]) -> int:
    total = 0
    for i in lst:
        total += i
    return total

在实际使用中,我们可能会允许一个参数可以是list或者tuple,那么我们可以引入更抽象的Sequence

可以看到,Sequence不仅支持listtuple,还支持byterange

字典类型标注

由于dict是有key和value的,因此需要同时对两者进行类型注解,中间用,隔开:

允许多种数据类型的标注

在很多情况下,我们允许一个参数传入int/None多种数据类型,那么可以这样表示:

而在Python3.10之后也可以简写为:

由于参数允许None是很常见的,所以Python也提供了Optional,默认是包含None类型的,这样写起来更简洁:

也就是说,以上这3种写法都是等价的(注意第二种写法仅在Python3.10之后支持)。

小结

本文是对Python类型标注的一个基础用法进行简单讲解,看完之后就可以尝试着在我们的Python项目中增加类型标注了。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-09-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 类型标注的优点
  • 静态分析工具mypy
  • 自定义数据类型的类型标注
  • 列表类型标注
  • 字典类型标注
  • 允许多种数据类型的标注
  • 小结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档