This project contains a Cookiecutter template that helps you create new Python 3.7+ package projects by automatically generating most of the boiler plate content for you.
Cookiecutter is a command-line utility that creates projects from templates. Cookiecutter lets you to easily and quickly bootstrap a new project from a template which allows you to skip all manual setup and common mistakes when starting a new project.
Cookiecutter takes a source directory tree and copies it into your new project.
It replaces all the names that it finds surrounded by templating tags {{
and }}
with names that it finds in the file cookiecutter.json
.
The Python project structure produced by this Cookiecutter template contains the following items:
- A minimal README.rst file.
- A Makefile that automates many common developer tasks, such as:
- Creating a Virtual environment
- Checking code style.
- Performing static analysis checks.
- Running unit tests.
- Checking code coverage.
- Generating documentation.
- Generating, testing and uploading a project release to PyPI.
- A
setup.py
file used to generate project install and releases. - A
CONTRIBUTING.rst
guide. On Github this file is shown when sending a pull request or an issue. This file also gets included in the generated developer documentation. - An empty
CHANGELOG.rst
file. This file gets included in the user documentation. - A
LICENSE
file (orCOPYING
for GNU licenses) that defaults to the Apache License version 2.0. - An
examples
directory with a minimal quickstart example script. This script imports the package and prints the package version. It is also called by the unit test suite to ensure it always works. - A
tests
directory containing a basic unit test (using unittest) and a shell script that can be used to test a wheel distribution of the package. - A Github Actions continuous integration configuration.
- A
docs
directory with pre-configured Sphinx documentation containing:- A minimal
index.rst
page - A user focused page containing information such as installation instructions, API docs, a link to the change log and instructions about how to raise a bug.
- A developer focused page containing information such as contributing, testing, code coverage, style compliance, type annotations and documentation.
- A minimal
It is assumed that the new Python package will eventually be:
- hosted on Github (or perhaps GitLab)
- published to PyPI
- linked to ReadTheDocs.
The generated docs have some references and links to those sites.
The process for using Cookiecutter to create a new Python package project
starts with installing Cookiecutter. This is best done by creating a new
virtual environment specifically for cookiecutter and then installing
cookiecutter using pip
. The example below shows how to do this.
$ python -m venv ccvenv --prompt cc
$ source ccvenv/bin/activate
(cc) $ pip install pip -U # update pip to avoid any warnings
(cc) $ pip install cookiecutter
You are now ready to create a new Python project from the Cookiecutter template provided by this project.
To create a new Python package project based on this cookiecutter template
simply navigate to a directory where you want to create the new project, then
run the cookiecutter
command with a command line argument referencing this
template.
The easiest method is to reference this template via its Github URL (where 'gh' is a shortened form for Github):
(cc) $ cookiecutter gh:boltronics/cookiecutter-python-project
Alternatively, if you have cloned a local copy of this template you can reference it directly:
(cc) $ cookiecutter path/to/cookiecutter-python-project
You will be prompted for user input to configure the project. Prompts are the keys in 'cookiecutter.json' and default responses are the values. Prompts are shown in order.
Once you have generated your new Python package project you can exit the cookiecutter virtual environment as it is no longer required.
(cc) $ deactivate
$
Some aspects of generating a project in a generic approach are not practical to completely automate so there may be a few steps remaining before you begin using the new project.
- If you do not plan to publish project artifacts at GitHub, PyPI or
ReadTheDocs then remove any links to those sites. Affected files are:
- README.rst
- setup.py
- docs/source/index.rst
- Update any additional useful classifiers in
setup.py
. The list of available classifiers can be found here.
Below is an example showing exactly how to create a new Python project using
the template in this project. In this scenario the project is called
abc 123
and the Python package is called abc_123
.
It is assumed that you have performed the actions outlined in the One Time Setup Steps section above which provides a virtual environment with cookiecutter installed into it.
After running the cookiecutter command and passing it a reference to this template the first question it asks for is the package display name. This is the human friendly label that will be used in docs to refer to the project. It is also used to create the package name so it should not contain special characters that are invalid when used in a Python attribute. It can have spaces and hyphens in it. The package display name is first converted to lowercase text and then any spaces or hyphens are converted to underscores to produce a Python package name.
(cc) $ cookiecutter ../cookiecutter-python-project/
package_display_name [Package-Name]: abc 123
package_name [abc_123]:
package_short_description [A description of the package]: This is my abc 123 package.
version [0.0.1]:
full_name [Your Name]: First Last
email []:
github_user_name [GithubUserName]: flast
github_repo_name [abc_123]:
Select license:
1 - Apache License, Version 2.0
2 - Expat License
3 - GNU GPL version 2
4 - GNU GPL version 3
5 - GNU AGPL version 3
6 - Modified BSD license (3-clause)
7 - Not licensed for distribution (no license)
Choose from 1, 2, 3, 4, 5, 6, 7 [1]:
year [2023]:
The project has been created in the abc_123
directory.
$ cd abc_123
We can now kick the tires of this new project by performing some initial project checks.
First, let's create a project specific virtual environment and activate it.
This will install all of the project's development dependencies as well as
the project itself. The project will be installed as an editable package (by
using the -e
flag to pip
).
$ make venv
...
Enter virtual environment using:
source venv/abc_123/bin/activate
$ source venv/abc_123/bin/activate
(abc_123) $
Now that we have a virtual environment we can check the remaining convenience functions provided by the Makefile.
(abc_123) $ make style
(abc_123) $ make check-style
(abc_123) $ make check-static-analysis
(abc_123) $ make test
(abc_123) $ make test-verbose
(abc_123) $ make coverage
(abc_123) $ make check-docs
(abc_123) $ make docs
(abc_123) $ make serve-docs # in browser navigate to http://localhost:8000/html
(abc_123) $ make dist
(abc_123) $ make dist-test