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 必须在最前),它需要明确知道哪些导入属于哪一组。

人民网AIGC-X
人民网AIGC-X

国内科研机构联合推出的AI生成内容检测工具

下载
  • 确保 [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,避免因缓存导致规则更新后未生效。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
format在python中的用法
format在python中的用法

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

887

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

461

2024.06.27

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1925

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

656

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2395

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

47

2026.01.19

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

954

2023.09.19

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

38

2026.03.10

热门下载

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

精品课程

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

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

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

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