Skip to main content

Add your description here

Project description

PyHatchery 🐍🥚

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.0.tar.gz (40.2 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.0-py3-none-any.whl (5.0 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for pyhatchery-0.2.0.tar.gz
Algorithm Hash digest
SHA256 fb3f04737052925c61173d5b7fa938af798a98576e99175baac60285fb370175
MD5 17129499ac43b00b8cc37abbf58d2e35
BLAKE2b-256 88904fc79dadebea20105add5afe47543e769f269d3db192908c101ce40f4909

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyhatchery-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 64fcdfec532935186b4a6e9db24503b3993f3f453aaf319ae3f96fac37a6d167
MD5 796b72040fe46fcc3e43b0cfc32d92d0
BLAKE2b-256 7cbef2608f959d60625b0b9e83128d5273f6d23e4dbae72179460ed76ab5dcf9

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