0

0

Python pyright vs mypy 的团队选型

冰川箭仙

冰川箭仙

发布时间:2026-02-16 09:05:26

|

430人浏览过

|

来源于php中文网

原创

ci 中优先用 mypy,因其检查更严格稳定;pyright 更适合开发时实时反馈。两者需统一 python_version 配置,noreturn 应显式标注,第三方 stub 缺失时 mypy 更敏感,配置应按阶段分离。

python pyright vs mypy 的团队选型

pyright 和 mypy 哪个更适合 CI 流水线

pyright 更快,mypy 更准——但“快”在 CI 里不等于“好”。pyright 默认跳过未 import 的模块类型检查,pyright --skipunresolved 开启后才接近 mypy 行为;而 mypy 的 --follow-imports=normal(默认)会递归解析所有依赖,容易因第三方包缺失 stub 导致失败。

实操建议:

  • CI 中优先用 mypy,尤其当项目已用 pyproject.toml 配置了 [tool.mypy] 且团队熟悉其报错风格
  • 若用 pyright,必须显式加 --verify-types + --skip-unresolved=false,否则会漏掉 from missing_module import X 这类硬错误
  • 两者都需统一 python_version 配置,否则 Literal["a", "b"] 在 Python 3.8 下可能被 mypy 当成语法错误,pyright 却默许

遇到 NoReturn 报错时该信谁

mypy 对 NoReturn 更严格:函数末尾无 return、抛异常但没标注 -> NoReturn,它会警告“missing return statement”;pyright 则倾向静态推断,只要路径终点是 raisesys.exit() 就默认接受。

常见错误现象:

立即学习Python免费学习笔记(深入)”;

  • mypy 报 Missing return statement,但代码实际不会走到末尾(比如最后是 assert False
  • pyright 不报,但 mypy 在 CI 失败,引发“本地能过、CI 红了”的困惑

解决方法:

  • 统一用 typing.NoReturn 显式标注函数签名,别依赖推断
  • 避免 assert False 作终止,改用 raise NotImplementedError() —— mypy 认这个,pyright 也认
  • 如果用 sys.exit(),加上 # type: ignore 注释不如直接标注返回类型,更稳定

第三方库类型缺失导致的假阳性差异

两者对 types-* stub 包的依赖程度不同:mypy 强制要求所有导入模块有 stub(哪怕空的 py.typed 文件),pyright 默认容忍无类型模块,只给弱提示。

文赋Ai论文
文赋Ai论文

专业/高质量智能论文AI生成器-在线快速生成论文初稿

下载

使用场景:

  • 项目用了 requests 但没装 types-requests:mypy 报 error: Module has no attribute "get",pyright 只标灰(any 类型)不中断检查
  • 团队引入新 SDK,还没发布 stub:mypy 需临时加 [mypy-xxx] ignore_missing_imports = true,pyright 可先不管

参数差异:

  • mypy 的 ignore_missing_imports = true 是全局开关,关了就全严,开了就全松
  • pyright 的 "reportMissingImports": "none" 可按文件粒度控制,在 pyrightconfig.json 里配 "include": ["src/"],不影响测试目录

VS Code 插件体验和配置冲突点

VS Code 默认 Python 扩展内置 pyright,开箱即用;mypy 需手动装 mypy + python-mypy 插件,且两者不能共存于同一工作区的实时检查中——会重复报错。

容易踩的坑:

  • 同时启用 mypy 插件和 Pylance(含 pyright),编辑器右下角显示两个类型检查器图标,但只有一套诊断结果生效,另一套静默失效
  • pyright 的 typeCheckingMode 设为 basic 时,连 str.join(list[int]) 这种明显错误都不报,误以为“没问题”
  • mypy 的 cache_dir 若指向 NFS 或 Docker volume,首次运行极慢,但 pyright 的增量缓存对远程文件系统更友好

实操建议:

  • 开发时用 pyright(快 + 实时响应),CI 用 mypy(稳 + 报错一致)——靠 pyproject.toml 分离配置,不是靠插件开关
  • 禁用 Pylance 的类型检查("python.analysis.typeCheckingMode": "off"),只留其智能补全能力,把类型检查权交给独立 mypy 进程

类型检查器不是非此即彼的选择,而是检查阶段、精度粒度、团队习惯的组合。最常被忽略的是:mypy 的 disallow_untyped_defs 和 pyright 的 reportUntypedFunctionDecorator 表面相似,实际约束范围差两层抽象——一个管函数体,一个只管装饰器本身。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

441

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

321

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

351

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.25

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

750

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

568

2024.08.29

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号