2026年の最新Python開発テンプレート
Project description
Python Project 2026
2026年の最新Python開発テンプレート - uv、ruff、pytestを使った現代的な開発環境
🚀 クイックスタート
ワンコマンドで新しいPythonプロジェクトを作成:
curl -fsSL https://raw.githubusercontent.com/koboriakira/python-project-2026/main/install.sh | sh -s my-new-project
作成後:
cd my-new-project
uv run pytest # テスト実行
uv run my-new-project --help # アプリケーション確認
📋 テンプレートとして使用
手動でテンプレートを使用する場合:
# このリポジトリをクローン
git clone https://github.com/koboriakira/python-project-2026.git
cd python-project-2026
# 新しいプロジェクトを作成
./install.sh my-new-project
# 作成されたプロジェクトに移動
cd my-new-project
# 開発開始!
uv run pytest # テスト実行
uv run my-new-project --help # アプリケーション確認
install.shの機能
- ✅ 自動ダウンロード: GitHubから最新のテンプレートを取得
- ✅ 完全なファイルコピー: すべてのテンプレートファイルを新しいディレクトリにコピー
- ✅ 名前の一括置換: プロジェクト名・パッケージ名を適切に変換
- ✅ Git初期化: 新しいGitリポジトリの初期化と初回コミット
- ✅ 環境セットアップ: uv syncによる依存関係のインストール
- ✅ エラーハンドリング: 無効な名前や既存ディレクトリの検証
特徴
- 🚀 超高速: uvによる爆速パッケージ管理
- 🛠️ 最新ツール: ruff、mypy、pytest、Claude Code hooks、pre-commit
- 📦 モダンな構成: pyproject.tomlによる一元管理
- 🧪 完全なテスト: カバレッジ測定とCI/CD
- 🔧 開発者体験: リンター、フォーマッター、型チェック
- 🚀 自動リリース: release-pleaseによるセマンティックバージョニング
必要要件
- Python 3.12+
- uv (推奨)
セットアップ
uvを使用(推奨)
# uvのインストール(まだの場合)
curl -LsSf https://astral.sh/uv/install.sh | sh
# プロジェクトのセットアップ
uv sync
# 品質管理ツールのセットアップ
uv run pre-commit install # Git hooks(手動開発時)
# Claude Code hooks(AI統合)は .claude/settings.local.json で設定済み
従来の方法
python -m venv venv
source venv/bin/activate # Windows: venv\Scripts\activate
pip install -e ".[dev]"
pre-commit install
開発コマンド
# テスト実行
uv run pytest
# テスト(カバレッジ付き)
uv run pytest --cov
# コードフォーマット
uv run ruff format .
# リンティング
uv run ruff check .
# 型チェック
uv run mypy
# 品質チェック実行
.claude/scripts/pre-commit-replacement.sh # Claude Code hooks(推奨)
uv run pre-commit run --all-files # 従来のpre-commit
# アプリケーション実行
uv run python-project-2026 hello --name "開発者"
プロジェクト構造
python-project-2026/
├── src/
│ └── python_project_2026/
│ ├── __init__.py
│ ├── main.py
│ └── utils.py
├── tests/
│ ├── test_main.py
│ └── test_utils.py
├── pyproject.toml
├── README.md
└── .pre-commit-config.yaml
設定ファイル
すべての設定は pyproject.toml に統一されています:
- ruff: リンティングとフォーマット
- pytest: テストの実行と設定
- mypy: 型チェック
- coverage: カバレッジ測定
CI/CD
GitHub Actionsによる自動化:
- マルチプラットフォーム(Linux、Windows、macOS)
- 複数Python バージョン(3.12、3.13)
- テスト、リンティング、型チェック
- セキュリティ監査
自動リリース管理
release-pleaseによる自動リリース:
Conventional Commits使用例
# パッチバージョン更新 (0.1.0 → 0.1.1)
git commit -m "fix: バリデーションエラーを修正"
# マイナーバージョン更新 (0.1.0 → 0.2.0)
git commit -m "feat: 新しい機能を追加"
# メジャーバージョン更新 (0.1.0 → 1.0.0)
git commit -m "feat!: 破壊的変更を実装"
自動化される処理
- バージョン更新: Conventional Commitsに基づいてセマンティックバージョニング
- CHANGELOG生成: コミットメッセージから自動的にCHANGELOGを更新
- GitHub Releases: 新しいバージョンのリリースを自動作成
- PyPI公開: 本番環境とテスト環境への自動パッケージ公開
ライセンス
MIT License
Project details
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 python_project_2026-0.2.0.tar.gz.
File metadata
- Download URL: python_project_2026-0.2.0.tar.gz
- Upload date:
- Size: 98.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a6015c203257467cd5089c1bf7715a82799dafc02ce5fa3bd8ea18fbcce5b3d3
|
|
| MD5 |
5358953d51406cd5815f7d7ca47bf04b
|
|
| BLAKE2b-256 |
9c2e0f3270b24f8842d2c49c6d6dbaef1fbea2d1530c09d54a8e7146036147fe
|
Provenance
The following attestation bundles were made for python_project_2026-0.2.0.tar.gz:
Publisher:
release-please.yml on koboriakira/python-project-2026
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_project_2026-0.2.0.tar.gz -
Subject digest:
a6015c203257467cd5089c1bf7715a82799dafc02ce5fa3bd8ea18fbcce5b3d3 - Sigstore transparency entry: 786812319
- Sigstore integration time:
-
Permalink:
koboriakira/python-project-2026@288f5dc223c7b06fc9a84e96f9310b38915eccf5 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/koboriakira
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-please.yml@288f5dc223c7b06fc9a84e96f9310b38915eccf5 -
Trigger Event:
push
-
Statement type:
File details
Details for the file python_project_2026-0.2.0-py3-none-any.whl.
File metadata
- Download URL: python_project_2026-0.2.0-py3-none-any.whl
- Upload date:
- Size: 6.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8e36da8a4b0d907e85e3f25aafe19cbf9cab1a05f2eafa3526fb5c45330bbd82
|
|
| MD5 |
c61b655d31bee2c05d89a94fcbcefb30
|
|
| BLAKE2b-256 |
f5d5091a4b51652da40ce2164c0be14dafa58920cbc8fe36378bcc8abbb43538
|
Provenance
The following attestation bundles were made for python_project_2026-0.2.0-py3-none-any.whl:
Publisher:
release-please.yml on koboriakira/python-project-2026
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_project_2026-0.2.0-py3-none-any.whl -
Subject digest:
8e36da8a4b0d907e85e3f25aafe19cbf9cab1a05f2eafa3526fb5c45330bbd82 - Sigstore transparency entry: 786812333
- Sigstore integration time:
-
Permalink:
koboriakira/python-project-2026@288f5dc223c7b06fc9a84e96f9310b38915eccf5 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/koboriakira
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-please.yml@288f5dc223c7b06fc9a84e96f9310b38915eccf5 -
Trigger Event:
push
-
Statement type: