浅谈怎么给Python添加类型标注

作者:枇杷鹭 时间:2023-11-21 05:16:17 

Python 添加类型标注

Python 如此简洁,书写者在声明变量时甚至无需考虑类型。

但是简洁与复杂间,是存在一个平衡点的。当我们书写较为复杂的项目时,还是希望可以拥有「静态类型语言」强大的类型检查和智能的提示。

好消息是,并不需要像 TypeScript 那样,引入一个新的编译器来给 JavaScript 做“升级”来进行类型检查, Python 自带的 typing 工具可以在一定程度上把 Python 变成「静态类型语言」;坏消息是, Python 归根结底不是「静态类型语言」,经过我的简单测试,其代码还是「自由松散」的。

给 Python 标注类型

首先和读者声明我们的实验环境。


❯ python --version
Python 3.7.0

本文参考了 Python3.7 的 中文文档 。

我们声明一个变量,通过如下方式声明类型:


a: int = 1
b: float = .2
print(f'{a}, {b}')  # 1, 0.2

遗憾的是,在 Python 中,a: int = 1 这句话并没什么意义,说的直白点,就是『脱裤子放屁』;再说得好听点, Python 的类型标注放在这里这么用完全没有必要。

首先, a = 1 中解释器会自动把 a 推断为 int 类型,诸如 Pylance 的 Language Server 也会在我们书写时提供 int 的方法补全。

浅谈怎么给Python添加类型标注

此外,就算我们把 a 的类型规定为 int ,然后将 str 赋给 a ,解释器和 Language Server 也完全不会报错。如下。


a: int
a = '1'
print(a)  # 非常迷

做上述类型检查对于现代编译技术而言应该是毫无难度的,但这里就是没有报错、没有警告。这大概与 Python 的设计哲学有关。

我们看看 TypeScript 是如何表现的:

浅谈怎么给Python添加类型标注

TypeScript 把自己当作静态类型语言,要求书写时就确保类型的正确性。

使用 typing

尽管 Python 并不强制要求类型的正确性,并且会自动帮我们做强类型转换,但是我们依旧可以享受类型标注带来的诸多便利。

比如,我们现在要定义一个函数 foo ,函数返回一个列表 dogList ,列表中的元素都是我们自定义的类 Dog 的实例。

如果没有类型标注,我们无法获得智能提示,如下。

浅谈怎么给Python添加类型标注

Python 中从来就不要求 List 对象中的元素都是同一类型,因此,解释器或者 Language Server 也不会「吃力不讨好」般地去把程序运行一遍,然后推断你这个 List 里放的东西是什么类型。

自然,当你从 List 中拿元素时(比如上述的 dogList[0] ),它没法告诉你 List 中你拿的元素是什么类型,也就没办法提示(No suggestion.)。

这与实际业务场景不符,因为我们写代码时,在一个列表中装入的往往都是同一类型。 为了在取元素时获得补全提示,我们可以使用 typing.List + 极简的泛型 。如下。

浅谈怎么给Python添加类型标注

我们规定, foo 返回的元素必是一个 List ,且其中元素类型是 Dog 类型。然后我们的 dogList[0] 也被识别成了 Dog 类型,获得了补全。舒服。

题外话:聪明的 Pylance

其实 Pylance 自己也可以做一些类型推导。比如我们使用生成器生成列表时, Pylance 就会判断这个列表中元素属于什么类型:

浅谈怎么给Python添加类型标注

结语

关于 typing 的用法,还有很多内容可以讨论,我的参考资料主要是:Python3.7 的 typing中文文档 。此外,用 Python 泛型实现函数重载相比静态类型语言似乎十分麻烦(我参考了Python实用宝典的文章(知乎)),如果之后我遇到合适的场景也会成文分享。

来源:https://blog.csdn.net/weixin_42815609/article/details/117630136

标签:Python,添加,类型标注
0
投稿

猜你喜欢

  • JavaScript解析任意形式的json树型结构展示

    2024-04-30 10:09:35
  • 100 个 Python 小例子(练习题四)

    2022-02-15 16:20:05
  • Python单元测试及unittest框架用法实例解析

    2022-06-18 05:35:29
  • Django项目优化数据库操作总结

    2024-01-20 11:25:50
  • 利用Python如何实现一个小说网站雏形

    2023-09-22 05:52:07
  • python+pygame实现简易五子棋小游戏的三种方式

    2023-09-26 06:01:43
  • 豆瓣可以做而且值得做的几件事情

    2009-04-24 12:07:00
  • 感觉很流畅的js实现的键盘控制(带惯性)

    2024-04-30 10:11:38
  • 一个asp版的xheditor上传图片服务器端文件

    2009-12-21 14:18:00
  • Python自动化实现抖音自动刷视频

    2022-06-05 19:12:37
  • Python爬虫,获取,解析,存储详解

    2023-12-21 15:03:23
  • python 动态调用函数实例解析

    2021-03-11 09:31:41
  • 详解git reset 加不加 --hard的区别

    2022-04-03 06:45:13
  • php发送get、post请求的6种方法简明总结

    2023-11-14 12:59:43
  • js动态创建、删除表格示例代码

    2024-04-19 09:54:37
  • SSM实现mysql数据库账号密码密文登录功能

    2024-01-28 16:52:30
  • 批量替换sqlserver数据库挂马字段并防范sql注入攻击的代码

    2024-01-28 08:03:47
  • 利用python对mysql表做全局模糊搜索并分页实例

    2024-01-20 05:29:47
  • Django框架模板介绍

    2021-07-05 07:34:18
  • mysql数据库密码忘记解决方法

    2024-01-16 11:52:23
  • asp之家 网络编程 m.aspxhome.com