0

0

ruff 如何配置才能同时替代 black + isort + flake8

舞姬之光

舞姬之光

发布时间:2026-01-24 11:43:09

|

642人浏览过

|

来源于php中文网

原创

Ruff 可原生替代 Black、isort、Flake8:只需在 pyproject.toml 中配置 [tool.ruff.format] 和 select = ["E", "F", "I", "UP"],启用 line-length = 88 并设 profile = "black" 即可实现格式化、导入排序与代码检查三合一。

ruff 如何配置才能同时替代 black + isort + flake8

用 Ruff 一键替代 Black、isort、Flake8 的最小可行配置

直接上答案:Ruff 原生支持三合一,无需额外工具。只要在 pyproject.toml 中启用 format + lint 两套配置,并选对规则集,就能完全取代 blackisortflake8 —— 不是“模拟”,而是功能覆盖+行为对齐。

  • ruff format 替代 black:控制缩进、引号、换行、逗号等所有格式细节
  • ruff check 启用 "E"(pycodestyle)、"F"(pyflakes)、"I"(isort)规则组,就覆盖了 flake8 + isort --check 的全部检查能力
  • 不需要 isort 单独安装或运行;ruff check --fix 会自动重排导入、合并/删除未使用项

关键配置项怎么写才不翻车

常见错误是照抄旧 Flake8 配置却忽略 Ruff 的语义差异。比如把 ignore = ["E501"] 直接搬过去,但 Ruff 默认已用 line-length 控制长度,E501 已被自动禁用——多写反而干扰逻辑。

  • 格式化必须显式开启 [tool.ruff.format],否则 ruff format 命令无效(默认只做 lint)
  • 导入排序要启用 "I" 规则,不是靠 isort 插件: select = ["E", "F", "I", "UP"]
  • 行长度统一由 line-length = 88(推荐值)控制,不要再在 lint.ignore 里写 E501
  • 若项目用 black 风格,isort 必须设为 profile = "black" —— 但 Ruff 内置的 "I" 规则已自动适配该风格,无需额外配置

为什么 ruff check --fix 有时不重排导入?

这是最常被卡住的点:你写了 "I",也加了 --fix,但 import 块纹丝不动。根本原因是 Ruff 默认只修复「安全」问题,而导入重排涉及语义顺序(如 from __future__ import 必须在最前),它需要明确知道哪些导入属于哪一组。

零一万物开放平台
零一万物开放平台

零一万物大模型开放平台

下载
  • 确保 [tool.ruff.lint.isort] 下定义了 known-first-party(如 ["myproject"]),否则 Ruff 把所有包都当第三方处理,分组失效
  • 检查是否漏了 src = ["myproject"] —— Ruff 需靠它识别第一方模块路径
  • 避免在 per-file-ignores 中误关了 I 类规则,例如:"__init__.py" = ["I001"] 会跳过该文件所有导入检查

迁移到 Ruff 后,CI 和编辑器怎么改?

不用大动干戈。Ruff 兼容 Flake8 和 Black 的 CLI 接口,多数 CI 脚本只需改一个命令名;编辑器插件也基本无缝切换。

  • CI 中替换:把 flake8 .ruff check .black --check .ruff format --check .
  • VS Code 用户装官方 Ruff 插件后,在设置里关掉 Python: Formatting Provider(原 black)和 Python: Linting Enabled(原 flake8),Ruff 自动接管
  • 注意:Ruff 的 --fix 默认不修 W 类警告(如 W292 换行缺失),如需,得显式加 --unsafe-fixes(仅限确定安全时)

真正容易被忽略的是缓存行为:Ruff 会跳过未修改文件,这在本地开发很爽,但在 CI 中若用增量构建,可能漏检。建议 CI 固定加 --no-cache,避免因缓存导致规则更新后未生效。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

773

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

684

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

765

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

699

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1405

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

570

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

751

2023.08.11

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

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

精品课程

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

共4课时 | 16.7万人学习

Django 教程
Django 教程

共28课时 | 3.4万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

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

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