Skip to main content

Add your description here

Project description

PyHatchery 🐍🥚

cute snake hatching

Hatch new Python projects instantly!

PyHatchery is a command-line tool that generates a standardized, best-practice project structure with modern tooling like uv for dependency management, and ruff and pylint for linting/formatting, all pre-configured.

Stop wrestling with boilerplate and start coding faster. Inspired by the efficiency of hatchling, PyHatchery helps you seamlessly start new Python projects with a well-organized structure in minutes!

Key Goals & Features

  • 🚀 Rapid Project Scaffolding: Generate a complete project skeleton with a single command.
  • 🛠️ Modern Tooling Pre-configured: Comes with:
    • uv for lightning-fast dependency management and virtual environments.
    • ruff and pylint configurations for immediate code quality checks.
    • (hatchling for building the package).
  • ⚙️ Best Practices Baked In: Standardized directory layout, basic testing setup, .gitignore, and essential configuration files.
  • 📝 Automated Personalization: Automatically customizes project name, author details, and license information.
  • Standardized: Ensures consistency across your Python projects, making them easier to navigate and maintain.
  • 🌱 Foundation for Growth: Provides a solid, clean base for projects of any scale.

Installation

You can install PyHatchery directly from PyPI:

pip install pyhatchery

How it Works: The PyHatchery Wizard

Using PyHatchery is designed to be simple and intuitive. Open your terminal and run:

# TODO: This needs to be fleshed out...
pyhatchery new your_project_name

PyHatchery will then typically:

  1. Ask for Project Details: Prompt you for information such as:
    • Author Name (e.g., "Your Name")
    • Author Email (e.g., "your.email@example.com")
    • Project Description (a short summary of your project)
  2. Clone Template: Internally, it clones its built-in, best-practice project template.
  3. Personalize Files: It intelligently updates key files (like pyproject.toml, LICENSE, README.md_template) with your provided project name, author details, and the current copyright year.
  4. Finalize Structure: Sets up a fresh project structure in a new directory named your_project_name.
  5. Clean Up: Removes the template's .git history, allowing you to initialize your own version control.

Once completed, navigate to your new project:

cd your_project_name

Your new Python project is ready. You can now initialize your own Git repository if you wish

git init
git add .
git commit -m "Initial project structure from PyHatchery"

Start developing!

Post-Setup Recommendations

After your project is hatched, you might want to:

  • Review the generated README.md in your new project and fill in your project's specific details.
  • Begin outlining your project's design in docs/design.md.
  • To enable auto-publishing of your package to TestPyPI and PyPI (on pushes to develop and main, respectively) via the included GitHub Actions workflow:
    1. In your new project, set ENABLE_PUBLISHING to true in .github/workflows/publish.yml.
    2. Add the necessary PYPI_API_TOKEN (for PyPI) and TEST_PYPI_API_TOKEN (for TestPyPI) as GitHub Actions secrets to your new repository.
  • To enforce Git PR discipline in your new repository, consider creating Git branch protection rules or rulesets as outlined in PyHatchery's docs/contributing.md (adapt as needed for your project).

Happy hacking!!!

Understanding the Project Structure (Optional)

PyHatchery creates projects based on its embedded template structure. This includes a standard layout for Python projects, such as:

  • your_project_name/: The main package directory.
  • tests/: For your unit and integration tests.
  • docs/: For project documentation.
  • pyproject.toml: Pre-configured for uv, hatchling, ruff, pylint, and your project metadata.
  • LICENSE: Typically an MIT License, personalized with your details.
  • .gitignore: A standard Python .gitignore file.
  • GitHub Actions workflows for testing and publishing.
  • .pylintrc and .ruff.toml settings files.

This structure is designed to be a comprehensive starting point.

Contributing

Feedback on PyHatchery itself is highly welcome! Please open an issue on the PyHatchery GitHub repository to share your thoughts, suggestions, or report bugs.

Read the contribution document here and please follow the guidelines for this repository.

License

PyHatchery is licensed under the MIT License. Generated projects will also include a personalized MIT License by default.

Copyright (c) 2025, Kayvan Sylvan


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

pyhatchery-0.2.2.tar.gz (176.0 kB view details)

Uploaded Source

Built Distribution

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

pyhatchery-0.2.2-py3-none-any.whl (5.1 kB view details)

Uploaded Python 3

File details

Details for the file pyhatchery-0.2.2.tar.gz.

File metadata

  • Download URL: pyhatchery-0.2.2.tar.gz
  • Upload date:
  • Size: 176.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.3

File hashes

Hashes for pyhatchery-0.2.2.tar.gz
Algorithm Hash digest
SHA256 6925c82ac974b1d9ac8af88e38c69135a80291b4c7780b19c8ffec44ae8a1cad
MD5 6946e8fcd53d8eb80c0459036e801645
BLAKE2b-256 3714555c589554cbb7fceb9ac3fec8181b09143baf420bc5ba439ffe0c4523c1

See more details on using hashes here.

File details

Details for the file pyhatchery-0.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for pyhatchery-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 2795c04be33e5bff17be2ed5e0bca4195fa92d51433acb7bc077f92a52780c62
MD5 3d8b4d801d25ca3a029b794e6db77d1e
BLAKE2b-256 dc3e6a82b4f4a02363d13e53b04e9a99d9a57c352d6839b8aefacbf0f424ed88

See more details on using hashes here.

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