Skip to main content

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

python_project_2026-0.3.0.tar.gz (113.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

python_project_2026-0.3.0-py3-none-any.whl (8.8 kB view details)

Uploaded Python 3

File details

Details for the file python_project_2026-0.3.0.tar.gz.

File metadata

  • Download URL: python_project_2026-0.3.0.tar.gz
  • Upload date:
  • Size: 113.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for python_project_2026-0.3.0.tar.gz
Algorithm Hash digest
SHA256 926d00769b3e2f7f8866e25e754090d9d7da8c5d843812b3d3c700949cfc2349
MD5 547f2fa1eeb28f51ed18f67a88a2e574
BLAKE2b-256 722e8f5762097b18b9945774ad7bf70752244c74fadb68cce26911d2dc7ee80a

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_project_2026-0.3.0.tar.gz:

Publisher: release-please.yml on koboriakira/python-project-2026

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file python_project_2026-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for python_project_2026-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 03f83cbe5d5c696f348073fe910446384985af52c7c22a2706e7bfc7bc9ba2b7
MD5 dcd88e5ceb5fb819c2c9d06d1b0c0ea0
BLAKE2b-256 a935488c957c1582f7618fbadd8a09d1ead587e52a842f2507a38fc32ee82d9d

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_project_2026-0.3.0-py3-none-any.whl:

Publisher: release-please.yml on koboriakira/python-project-2026

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page