autoflake:Python 代码里没用的 import,让它自己清掉

autoflake:Python 代码里没用的 import,让它自己清掉

autoflake 在 GitHub 上拿了 957 Star。

这个小工具只做一件事:扫描 Python 代码,把没用的 import 和变量自动清掉。它底层用的是 pyflakes 来做静态分析。

1、这玩意儿是干嘛的

Python 项目写久了,文件顶部往往堆了一堆 import。有些模块引了但根本没用到,变量定义了也没下文。这些代码不会报错,运行也没问题,但读起来费劲,打包时还多了不必要的依赖。

autoflake 就是来处理这个问题的。跑一遍,未使用的 import 直接消失,没用的变量也能一并清理。默认还会把多余的 pass 语句去掉。

默认策略比较保守:只删标准库的未使用导入。毕竟第三方模块可能带有副作用,贸然删掉有风险。如果你确定安全,可以加参数让它处理所有 import。

2、为什么要用它

手动清理 import 很烦。文件少还能逐行检查,项目大了根本顾不过来。很多团队靠代码审查时人工盯,效率低还容易漏。

autoflake 把这件事自动化了。集成到 CI 或 pre-commit hook 里,每次提交前自动扫一遍,未使用的代码进不了仓库。它还支持配置文件,在 pyproject.toml 或 setup.cfg 里写好规则,团队里所有人跑出来的结果一致。

对于遗留项目,autoflake 也够用。递归跑一遍整个目录,陈旧代码里的无用 import 一次清理完。

3、怎么用

安装:

复制代码
pip install autoflake

单文件处理:

css 复制代码
autoflake --in-place example.py

加上未使用变量清理:

css 复制代码
autoflake --in-place --remove-unused-variables example.py

只检查不修改,适合 CI 场景:

css 复制代码
autoflake --check example.py

递归处理目录:

css 复制代码
autoflake --recursive --in-place .

清理所有未使用导入(不限于标准库):

arduino 复制代码
autoflake --remove-all-unused-imports example.py

配置文件示例,写入 pyproject.toml:

toml 复制代码
[tool.autoflake]
check = true
imports = ["django", "requests"]

某些 import 虽然没被直接引用,但确实有副作用。比如 Flask 里导入模块来注册路由,这种情况在行尾加 # noqa 即可跳过。

pre-commit 集成时,在 .pre-commit-config.yaml 里加入 autoflake hook,参数带上 --remove-all-unused-imports--in-place 就行。

4、适合哪些人用

  • 维护中大型 Python 项目、import 逐渐失控的开发者
  • 想在 CI 流程里加一道自动清理关卡的技术团队
  • 用 pre-commit 管理代码规范、希望减少人工审查负担的工程组
相关推荐
极光技术熊5 小时前
Spring AI 从入门到精通:构建你的 AI 开发知识体系
后端·github
用户39483951075536 小时前
怎么让我的 Agent 真正"懂"我?——关于记忆、经验学习与预测的一些真实体验
github
远航_12 小时前
git submodule
前端·后端·github
fthux14 小时前
如果你用 Mac,那你可能需要 Noti Shift
macos·开源·github
程序员天天困1 天前
Loop Engineering 实战:/goal 命令让 AI 自己写完整项目
github
徐小夕1 天前
我们开源了一款“框架无关”的思维导图编辑器,3分钟集成到任意系统
前端·javascript·github
小爷毛毛_卓寿杰1 天前
我把 397B 的「Agentic 大脑」塞进了 Xinference,一键部署 Nex-N2
人工智能·架构·github
小爷毛毛_卓寿杰1 天前
我把一个 3B 模型塞进了 Xinference,然后它干掉了 DeepSeek V3.2
人工智能·开源·github
凌奕1 天前
别用文档约束你的 Agent:聊聊 Agent 开发流程的思想
llm·github·agent
HelloGitHub2 天前
《HelloGitHub》第 123 期
开源·github