Python Formatters, Linters, and Testers Runner.
Project description
pyfltr: Python Formatters, Linters, and Testers Runner
Python / Rust / .NET / TypeScript・JavaScript / ドキュメントなど多言語プロジェクトの formatter・linter・testerを単一コマンドで並列実行するCLIツール。 (要Python 3.11以上)
特徴
- formatter・linter・testerをまとめて呼び出す
- 複数ツールの並列実行による総実行時間の短縮
- コーディングエージェント向けJSON Lines出力(
--output-format=jsonl) - 設定の集約:
pyproject.tomlに寄せた統一設定 - 除外指定(exclude)の書式差をツール間で吸収
- MCPサーバー(
pyfltr mcp) - シェル補完スクリプト生成
インストール
pip install pyfltr
# uv を使う場合
uv add --dev pyfltr
uvxでの実行も可能。
uvx pyfltr --help
Python系ツール(ruff / mypy / pylint / pyright / ty / pytest / uv-sort)を利用する場合は、extrasで追加依存を導入する。
pip install 'pyfltr[python]'
Python / JavaScript / Rust / .NETの各言語カテゴリに属するツールはすべて既定で無効(opt-in)である。
preset = "latest" + 言語カテゴリキー(python / javascript / rust / dotnet)のtrue指定だけで、
当該言語の推奨ツール一式が有効化される。
プリセット非収録のツール(tyなど)を追加したい場合のみ個別に{command} = trueを指定する。
詳細は設定項目を参照。
コーディングエージェント向け運用
コーディングエージェントから利用する経路は2種類ある。
直接呼び出し(シェルコマンドが実行できる環境):
# JSONL形式で全チェックを実行し、結果をエージェントが読み込む
uvx pyfltr run-for-agent
# 直前runで失敗したツール・ファイルだけ再実行
uvx pyfltr run-for-agent --only-failed
run-for-agentはpyfltr run --output-format=jsonlのエイリアス。
JSONL出力の末尾summary行で全体像を把握でき、必要に応じてdiagnostic行を参照することでトークン消費を抑えられる。
MCP経由(コーディングエージェントのMCPクライアント経由):
# コーディングエージェントへの登録例(コマンド形式)
claude mcp add pyfltr -- uvx pyfltr mcp
または設定ファイルに直接記載する方法:
{
"mcpServers": {
"pyfltr": {
"command": "uvx",
"args": ["pyfltr", "mcp"]
}
}
}
MCPツールrun_for_agentでpaths・commands・fail_fastを指定して実行できる。
ドキュメント
- https://ak110.github.io/pyfltr/ — 概要・対応ツール一覧・設定リファレンス
- https://ak110.github.io/pyfltr/llms.txt — LLM向け構造化インデックス
- docs/development/development.md — 開発者向け情報
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyfltr-3.4.4.tar.gz.
File metadata
- Download URL: pyfltr-3.4.4.tar.gz
- Upload date:
- Size: 390.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ef15a4272a11aad6bd0b9c6dc12773f8eac2c86113e4335837dc380124189e3a
|
|
| MD5 |
e60dedd38e0ed5dd57b5b3ef38a26bbb
|
|
| BLAKE2b-256 |
3100ae2f4a2e5eb477eff9670c9eba52394245f5f87d12a7cef74201c1a4a676
|
File details
Details for the file pyfltr-3.4.4-py3-none-any.whl.
File metadata
- Download URL: pyfltr-3.4.4-py3-none-any.whl
- Upload date:
- Size: 144.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d0070cff254e148dba5c673e2ed5e57679199a7740ae437ab70ef2e7a71a604d
|
|
| MD5 |
0d736752b140444b3cc611c726198770
|
|
| BLAKE2b-256 |
750be8ee5385f8e01bfb8a23c2a83f304e433f8b600862f7b7de9b410f2822da
|