首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >python静态类型检查工具mypy

python静态类型检查工具mypy

作者头像
zy010101
发布2022-05-05 16:11:01
发布2022-05-05 16:11:01
1.4K0
举报
文章被收录于专栏:程序员程序员

mypy介绍

mypy 是 Python 的一个可选静态类型检查器,旨在结合动态(或“鸭子”)类型和静态类型的优点。mypy 将 Python 的表达能力和便利性与强大的类型系统和编译时类型检查相结合。mypy 类型检查标准 Python 程序;使用任何 Python VM 运行它们,基本上没有运行时开销。

安装和使用

mypy需要python3.6+,然后使用pip直接安装即可。

代码语言:javascript
复制
pip3 install mypy

接下来就可以直接在使用mypy了,例如:

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

就可以实现对代码进行静态类型检查,但是前提是你的代码使用了类型注解,否则mypy什么也检查不出来。mypy检查的结果是基于类型注解的,这意味你可以忽略mypy所提示的错误,只把它当做警告。

默认情况下,mypy不会对动态类型函数进行类型检查。例如下面的代码:

代码语言:javascript
复制
def add(a:int, b:int) -> int:
    "整数相加"
    return a + b

add(1, 2)           # 静态类型检查通过
add("123", "qwe")   # 静态类型检查失败

使用mypy进行静态类型检查,结果如下所示:

代码语言:javascript
复制
test.py:17: error: Argument 1 to "add" has incompatible type "str"; expected "int"
test.py:17: error: Argument 2 to "add" has incompatible type "str"; expected "int"
Found 2 errors in 1 file (checked 1 source file)

mypy给出了错误提示,但是我们都知道add("123", "qwe")这行代码并不会出错,这就是Python的鸭子类型。如果我们想要上面的代码通过静态类型检查,可以有两种方式。

代码语言:javascript
复制
from typing import Any
def add(a:Any, b:Any) -> Any:
    return a + b

add(1, 2) 
add("123", "qwe") 

另外一种方式是告知mypv忽略此处的类型检查。

代码语言:javascript
复制
def add(a:int, b:int) -> int:
    return a + b

add(1, 2) 
add("123", "qwe")   # type: ignore

使用# type: ignore可以让mypy忽略对代码的静态类型检查。 目前,mypy依旧处于beta版本。关于mypy的更多信息,可以查看mypy.

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • mypy介绍
  • 安装和使用
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档