Cookiecutter
A cross-platform command-line utility that creates projects from cookiecutters (project templates), e.g. Python package projects, C projects.
Install / Use
/learn @cookiecutter/CookiecutterREADME
Cookiecutter
Create projects swiftly from cookiecutters (project templates) with this command-line utility. Ideal for generating Python package projects and more.
Installation
Install Cookiecutter as a CLI tool with uv:
uv tool install cookiecutter
Features
- Cross-Platform: Supports Windows, Mac, and Linux.
- User-Friendly: No Python knowledge required.
- Versatile: Compatible with Python 3.10 to 3.14.
- Multi-Language Support: Use templates in any language or markup format.
For Users
Quickstart
The most common way to use Cookiecutter is as a command line utility with a GitHub-hosted Cookiecutter template such as https://github.com/audreyfeldroy/cookiecutter-pypackage
Use a GitHub-hosted Cookiecutter template
# You'll be prompted to enter values.
# Then it'll create your Python package in the current working directory,
# based on those values.
# For the sake of brevity, repos on GitHub can just use the 'gh' prefix
$ uvx cookiecutter gh:audreyfeldroy/cookiecutter-pypackage
Use a local template
$ uvx cookiecutter cookiecutter-pypackage/
Use it from Python
If you plan to use Cookiecutter programmatically, please run uv add cookiecutter to add it to your project. Then you can import and use it like this:
from cookiecutter.main import cookiecutter
# Create project from the cookiecutter-pypackage/ template
cookiecutter('cookiecutter-pypackage/')
# Create project from the cookiecutter-pypackage.git repo template
cookiecutter('gh:audreyfeldroy/cookiecutter-pypackage')
If Cookiecutter saves you time, star it on GitHub so other developers can find it too.
Detailed Usage
- Generate projects from local or remote templates.
- Customize projects with
cookiecutter.jsonprompts. - Utilize pre-prompt, pre- and post-generate hooks.
For Template Creators
- Any language, any framework. A Cookiecutter template is just a directory with variables. It works for Python, Rust, Terraform, docs sites, whatever you build repeatedly.
- Hooks for the rest of the setup. Pre- and post-generate scripts (shell or Python) handle git init, dependency installs, or anything else your boilerplate needs.
- One file defines the interface.
cookiecutter.jsondeclares every variable and its default. Users answer prompts; the template does the rest.
Available Templates
Discover a variety of ready-to-use templates on GitHub.
Special Templates
Community
Join the community, contribute, or seek assistance.
Feedback
We value your feedback. Share your criticisms or complaints constructively to help us improve.
Waiting for a Response?
- Be patient and consider reaching out to the community for assistance.
- For enterprise support, contact support@feldroy.com.
Code of Conduct
Adhere to the PyPA Code of Conduct during all interactions in the project's ecosystem.
Acknowledgements
Created and led by Audrey M. Roy Greenfeld, supported by a dedicated team of maintainers and contributors.
Related Skills
node-connect
337.1kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
claude-opus-4-5-migration
83.1kMigrate prompts and code from Claude Sonnet 4.0, Sonnet 4.5, or Opus 4.1 to Opus 4.5
frontend-design
83.1kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
model-usage
337.1kUse CodexBar CLI local cost usage to summarize per-model usage for Codex or Claude, including the current (most recent) model or a full model breakdown. Trigger when asked for model-level usage/cost data from codexbar, or when you need a scriptable per-model summary from codexbar cost JSON.
