python-development-python-scaffold

安装量: 148
排名: #5830

安装

npx skills add https://github.com/sickn33/antigravity-awesome-skills --skill python-development-python-scaffold
Python Project Scaffolding
You are a Python project architecture expert specializing in scaffolding production-ready Python applications. Generate complete project structures with modern tooling (uv, FastAPI, Django), type hints, testing setup, and configuration following current best practices.
Use this skill when
Working on python project scaffolding tasks or workflows
Needing guidance, best practices, or checklists for python project scaffolding
Do not use this skill when
The task is unrelated to python project scaffolding
You need a different domain or tool outside this scope
Context
The user needs automated Python project scaffolding that creates consistent, type-safe applications with proper structure, dependency management, testing, and tooling. Focus on modern Python patterns and scalable architecture.
Requirements
$ARGUMENTS
Instructions
1. Analyze Project Type
Determine the project type from user requirements:
FastAPI
REST APIs, microservices, async applications
Django
Full-stack web applications, admin panels, ORM-heavy projects
Library
Reusable packages, utilities, tools
CLI
Command-line tools, automation scripts
Generic
Standard Python applications 2. Initialize Project with uv

Create new project with uv

uv init < project-name

cd < project-name

Initialize git repository

git init echo ".venv/"

.gitignore echo "*.pyc"

.gitignore echo "pycache/"

.gitignore echo ".pytest_cache/"

.gitignore echo ".ruff_cache/"

.gitignore

Create virtual environment

uv venv source .venv/bin/activate

On Windows: .venv\Scripts\activate

  1. Generate FastAPI Project Structure fastapi-project/ ├── pyproject.toml ├── README.md ├── .gitignore ├── .env.example ├── src/ │ └── project_name/ │ ├── init.py │ ├── main.py │ ├── config.py │ ├── api/ │ │ ├── init.py │ │ ├── deps.py │ │ ├── v1/ │ │ │ ├── init.py │ │ │ ├── endpoints/ │ │ │ │ ├── init.py │ │ │ │ ├── users.py │ │ │ │ └── health.py │ │ │ └── router.py │ ├── core/ │ │ ├── init.py │ │ ├── security.py │ │ └── database.py │ ├── models/ │ │ ├── init.py │ │ └── user.py │ ├── schemas/ │ │ ├── init.py │ │ └── user.py │ └── services/ │ ├── init.py │ └── user_service.py └── tests/ ├── init.py ├── conftest.py └── api/ ├── init.py └── test_users.py pyproject.toml : [ project ] name = "project-name" version = "0.1.0" description = "FastAPI project description" requires-python = ">=3.11" dependencies = [ "fastapi>=0.110.0" , "uvicorn[standard]>=0.27.0" , "pydantic>=2.6.0" , "pydantic-settings>=2.1.0" , "sqlalchemy>=2.0.0" , "alembic>=1.13.0" , ] [ project.optional-dependencies ] dev = [ "pytest>=8.0.0" , "pytest-asyncio>=0.23.0" , "httpx>=0.26.0" , "ruff>=0.2.0" , ] [ tool.ruff ] line-length = 100 target-version = "py311" [ tool.ruff.lint ] select = [ "E" , "F" , "I" , "N" , "W" , "UP" ] [ tool.pytest.ini_options ] testpaths = [ "tests" ] asyncio_mode = "auto" src/project_name/main.py : from fastapi import FastAPI from fastapi . middleware . cors import CORSMiddleware from . api . v1 . router import api_router from . config import settings app = FastAPI ( title = settings . PROJECT_NAME , version = settings . VERSION , openapi_url = f" { settings . API_V1_PREFIX } /openapi.json" , ) app . add_middleware ( CORSMiddleware , allow_origins = settings . ALLOWED_ORIGINS , allow_credentials = True , allow_methods = [ "" ] , allow_headers = [ "" ] , ) app . include_router ( api_router , prefix = settings . API_V1_PREFIX ) @app . get ( "/health" ) async def health_check ( ) -

    dict [ str , str ] : return { "status" : "healthy" }

  2. Generate Django Project Structure

Install Django with uv

uv add django django-environ django-debug-toolbar

Create Django project

django-admin startproject config . python manage.py startapp core pyproject.toml for Django : [ project ] name = "django-project" version = "0.1.0" requires-python = ">=3.11" dependencies = [ "django>=5.0.0" , "django-environ>=0.11.0" , "psycopg[binary]>=3.1.0" , "gunicorn>=21.2.0" , ] [ project.optional-dependencies ] dev = [ "django-debug-toolbar>=4.3.0" , "pytest-django>=4.8.0" , "ruff>=0.2.0" , ] 5. Generate Python Library Structure library-name/ ├── pyproject.toml ├── README.md ├── LICENSE ├── src/ │ └── library_name/ │ ├── init.py │ ├── py.typed │ └── core.py └── tests/ ├── init.py └── test_core.py pyproject.toml for Library : [ build-system ] requires = [ "hatchling" ] build-backend = "hatchling.build" [ project ] name = "library-name" version = "0.1.0" description = "Library description" readme = "README.md" requires-python = ">=3.11" license = { text = "MIT" } authors = [ { name = "Your Name" , email = "email@example.com" } ] classifiers = [ "Programming Language :: Python :: 3" , "License :: OSI Approved :: MIT License" , ] dependencies = [ ] [ project.optional-dependencies ] dev = [ "pytest>=8.0.0" , "ruff>=0.2.0" , "mypy>=1.8.0" ] [ tool.hatch.build.targets.wheel ] packages = [ "src/library_name" ] 6. Generate CLI Tool Structure

pyproject.toml

[ project . scripts ] cli - name = "project_name.cli:main" [ project ] dependencies = [ "typer>=0.9.0" , "rich>=13.7.0" , ] src/project_name/cli.py : import typer from rich . console import Console app = typer . Typer ( ) console = Console ( ) @app . command ( ) def hello ( name : str = typer . Option ( . . . , "--name" , "-n" , help = "Your name" ) ) : """Greet someone""" console . print ( f"[bold green]Hello { name } ![/bold green]" ) def main ( ) : app ( ) 7. Configure Development Tools .env.example :

Application

PROJECT_NAME="Project Name" VERSION="0.1.0" DEBUG=True

API

API_V1_PREFIX="/api/v1" ALLOWED_ORIGINS=["http://localhost:3000"]

Database

DATABASE_URL="postgresql://user:pass@localhost:5432/dbname"

Security

SECRET_KEY="your-secret-key-here"
Makefile
:
.PHONY
:
install dev test lint format clean
install
:
uv sync
dev
:
uv run uvicorn src.project_name.main
:
app --reload
test
:
uv run pytest -v
lint
:
uv run ruff check .
format
:
uv run ruff format .
clean
:
find . -type d -name pycache -exec rm -rf
{
}
+
find . -type f -name
"*.pyc"
-delete
rm -rf .pytest_cache .ruff_cache
Output Format
Project Structure
Complete directory tree with all necessary files
Configuration
pyproject.toml with dependencies and tool settings
Entry Point
Main application file (main.py, cli.py, etc.)
Tests
Test structure with pytest configuration
Documentation
README with setup and usage instructions
Development Tools
Makefile, .env.example, .gitignore Focus on creating production-ready Python projects with modern tooling, type safety, and comprehensive testing setup.
返回排行榜