ruff-formatting

安装量: 51
排名: #14493

安装

npx skills add https://github.com/laurigates/claude-plugins --skill ruff-formatting

ruff Formatting Expert knowledge for using ruff format as an extremely fast Python code formatter with Black compatibility. When to Use This Skill Use this skill when... Use another tool instead when... Formatting Python files Linting for code issues (use ruff check) Checking format compliance in CI Type checking (use basedpyright) Migrating from Black Detecting dead code (use vulture/deadcode) Setting up format-on-save Running tests (use pytest) Core Expertise ruff format Advantages 10-30x faster than Black Drop-in Black replacement (99.9% compatible) Written in Rust for performance Supports Black's configuration options Format checking and diff preview Respects .gitignore automatically Basic Usage Simple Formatting

Format current directory

ruff format

Format specific files or directories

ruff format path/to/file.py ruff format src/ tests/

IMPORTANT: Pass directory as parameter to stay in repo root

ruff format services/orchestrator Format Checking

Check if files are formatted (exit code 1 if not)

ruff format --check

Show diff without modifying files

ruff format --diff

Check specific files

ruff format --check src/ tests/

Preview changes before applying

ruff format --diff services/orchestrator ruff format services/orchestrator

Apply after review

Selective Formatting

Format only Python files

ruff format src/*/.py

Format excluding tests

ruff format --exclude tests/

Format only changed files (git)

git diff --name-only --diff-filter = d | grep '.py$' | xargs ruff format

Format files in specific directory

ruff format src/core/ src/utils/ Configuration pyproject.toml [ tool.ruff ] line-length = 88 target-version = "py39" [ tool.ruff.format ] quote-style = "double" indent-style = "space" skip-magic-trailing-comma = false line-ending = "auto" docstring-code-format = true docstring-code-line-length = "dynamic" exclude = [ ".pyi" , "/pycache" , "*/node_modules" , ".venv" , ] ruff.toml (standalone) line-length = 88 [ format ] quote-style = "single" indent-style = "space" skip-magic-trailing-comma = false docstring-code-format = true Black Compatibility [ tool.ruff ] line-length = 88 indent-width = 4 target-version = "py39" [ tool.ruff.format ] quote-style = "double" indent-style = "space" skip-magic-trailing-comma = false line-ending = "auto" Format Workflow Preview : ruff format --diff (see changes) Check : ruff format --check (CI validation) Apply : ruff format (modify files) Verify : ruff format --check (confirm) Best Practices Pass directory parameter directly: ruff format src/ Preview changes first with --diff Use one formatter per project (ruff format replaces Black) Exclude generated files in pyproject.toml Keep pre-commit config in sync with formatter choice Enable docstring-code-format for better docs Agentic Optimizations Context Command Format directory ruff format src/ Check formatting ruff format --check Show diff ruff format --diff CI check + diff ruff format --check --diff Format + lint ruff format && ruff check Format changed files git diff --name-only --diff-filter=d | grep '.py$' | xargs ruff format Quick Reference Essential Commands ruff format

Format current directory

ruff format path/to/dir

Format specific directory

ruff format --check

Check if formatted

ruff format --diff

Show formatting changes

ruff format file1.py file2.py

Format specific files

ruff format --exclude tests/

Exclude directory

ruff format --line-length 100

Override line length

Format vs Check Command Purpose Exit Code Modifies Files ruff format Format files 0 Yes ruff format --check Validate formatting 1 if unformatted No ruff format --diff Show changes 0 No ruff format --check --diff Validate + show 1 if unformatted No Configuration Quick Start Minimal (Black-compatible) [ tool.ruff ] line-length = 88 [ tool.ruff.format ] quote-style = "double" indent-style = "space" Recommended [ tool.ruff ] line-length = 88 target-version = "py311" [ tool.ruff.format ] quote-style = "double" indent-style = "space" skip-magic-trailing-comma = false docstring-code-format = true line-ending = "auto" exclude = [ ".pyi" , "migrations//.py" , ] For detailed examples, advanced patterns, integration guides, and migration checklists, see REFERENCE.md .

返回排行榜