0

0

Python mypy 的增量检查与缓存

舞姬之光

舞姬之光

发布时间:2026-02-23 19:17:43

|

897人浏览过

|

来源于php中文网

原创

增量检查未生效的根本原因是缓存被绕过:修改pyproject.toml/mypy.ini配置、__init__.py等顶层模块,或使用--follow-imports=normal但存在未安装包,均触发全量重检;可通过--verbose日志、.mypy_cache目录及二次运行耗时验证缓存是否工作。

python mypy 的增量检查与缓存

增量检查为什么没生效?

mypy 默认开启增量检查,但实际不提速,大概率是缓存被绕过了。根本原因不是它坏了,而是你改了某些触发全量重检的文件或配置。

  • pyproject.tomlmypy.ini 里修改了 pluginsdisallow_untyped_defs 等影响类型语义的配置项,mypy 会丢弃整个缓存
  • 修改了 __init__.py 或任何被其他模块 import 的顶层模块,它会重新计算依赖图,很多文件被迫重检
  • 用了 --follow-imports=normal(默认值),但实际项目里有本地未安装的包,mypy 会退回到慢速解析模式,缓存失效

怎么确认缓存是否在工作?

别猜,直接看输出和文件系统。mypy 不会主动告诉你“本次用了缓存”,得自己验证。

  • --verbose 运行一次,观察日志里有没有类似 cached: module_x, module_y 的行;没有就说明没走缓存路径
  • 检查 .mypy_cache/ 目录是否存在且有内容,特别是子目录名是否对应你的 Python 版本(如 3.11
  • 改一行无关代码(比如注释),再跑 mypy --show-traceback,如果报错位置和上次一样、耗时明显低于首次,基本可判定缓存生效

mypy --incremental 是不是必须加?

不是。从 mypy 0.900 开始,--incremental 已是默认行为,显式加上反而容易让人误以为它是“开关”。真正影响缓存行为的是以下几件事:

腾讯智影-AI数字人
腾讯智影-AI数字人

基于AI数字人能力,实现7*24小时AI数字人直播带货,低成本实现直播业务快速增增,全天智能在线直播

下载
  • 确保没传 --no-incremental —— 这个 flag 会强制禁用所有缓存逻辑
  • 避免混用 mypymypyc,后者有自己的缓存结构,会污染 .mypy_cache/
  • CI 环境里注意清理策略:有些流水线每次清空 workspace,导致缓存永远建不起来;建议保留 .mypy_cache/ 目录(但别提交到 git)

缓存文件能手动删吗?

能,而且有时必须删。缓存不是坚不可摧的,它会因类型信息不一致而卡住,表现是:明明改对了类型,mypy 还报老错。

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

  • 最安全的清理方式是 rm -rf .mypy_cache/,不要只删部分子目录
  • 如果只想清特定模块,可以用 mypy --clear-cache,但它只清内存映射,不删磁盘文件,效果有限
  • Python 升级后(比如从 3.11 切到 3.12),旧缓存目录不会自动废弃,mypy 可能读错版本对应的 cache,此时必须手动删

缓存机制本身不复杂,但它的边界条件很具体——它只信任“没动过”的文件和“没变过”的配置。一旦其中一环松动,它就退回全量模式,而且不提醒你。

相关文章

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

894

2023.07.05

git和svn的区别
git和svn的区别

git和svn的区别:1、定义不同;2、模型类型不同;3、存储单元不同;4、是否拥有全局版本号;5、内容完整性不同;6、版本库不同;7、克隆目录速度不同;8、分支不同。php中文网为大家带来了git和svn的相关知识、以及相关文章等内容。

575

2023.07.06

git撤销提交的commit
git撤销提交的commit

Git是一个强大的版本控制系统,它提供了很多功能帮助开发人员有效地管理和控制代码的变更,本专题为大家提供git 撤销提交的commit相关的各种文章内容,供大家免费下载体验。

273

2023.07.24

git提交错误怎么撤回
git提交错误怎么撤回

git提交错误撤回的方法:git reset head^:撤回最后一次提交,恢复到提交前状态。git revert head:创建新提交,内容与之前提交相反。git reset :使用提交的 sha-1 哈希撤回指定提交。交互式舞台区:标记要撤回的特定更改,然后提交,排除已撤回更改。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

566

2024.04.09

git怎么对比两个版本的文件内容
git怎么对比两个版本的文件内容

要对比两个版本的 git 文件,请使用 git diff 命令:git diff 比较工作树和暂存区之间的差异。git diff 比较两个提交或标签之间的差异。git diff 输出显示差异块,其中 + 表示添加的行,- 表示删除的行, 表示修改的行。可使用 gitkraken、meld、beyond compare 等可视化工具更直观地查看差异。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

531

2024.04.09

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

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

1127

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

361

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

243

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

37

2026.02.13

热门下载

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

精品课程

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

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.7万人学习

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

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