Python project template
Go to file Use this template
Simon Diesenreiter 1dc5d7a817
Some checks failed
Rename the project from template / rename-project (push) Has been skipped
SonarQube Scan / SonarQube Trigger (push) Has been skipped
CI / linter (ubuntu-latest, 3.9) (push) Failing after 14m35s
CI / tests_linux (ubuntu-latest, 3.9) (push) Has been cancelled
Merge pull request 'more bugfixes' (!1) from sidiesen/update into main
Reviewed-on: #1
2024-11-13 09:13:06 -08:00
.gitea more bugfixes 2024-11-13 18:11:55 +01:00
docs initial commit 2024-11-09 08:01:27 -08:00
project_name Revert " Ready to clone and code." 2024-11-09 09:05:53 -08:00
tests Revert " Ready to clone and code." 2024-11-09 09:05:53 -08:00
.gitignore initial commit 2024-11-09 08:01:27 -08:00
ABOUT_THIS_TEMPLATE.md remove release to PiPy 2024-11-10 07:37:23 -08:00
Containerfile Revert " Ready to clone and code." 2024-11-09 09:05:53 -08:00
CONTRIBUTING.md remove release to PiPy 2024-11-10 07:37:23 -08:00
HISTORY.md initial commit 2024-11-09 08:01:27 -08:00
LICENSE initial commit 2024-11-09 08:01:27 -08:00
Makefile more cleanup 2024-11-10 07:24:43 -08:00
MANIFEST.in Revert " Ready to clone and code." 2024-11-09 09:05:53 -08:00
mkdocs.yml Revert " Ready to clone and code." 2024-11-09 09:05:53 -08:00
README.md remove release to PiPy 2024-11-10 07:37:23 -08:00
requirements-test.txt initial commit 2024-11-09 08:01:27 -08:00
requirements.txt initial commit 2024-11-09 08:01:27 -08:00
setup.py Revert " Ready to clone and code." 2024-11-09 09:05:53 -08:00

Python Project Template

A low dependency and really simple to start project template for Python Projects.

See also

HOW TO USE THIS TEMPLATE

  1. Create a new repository from this template and choose a name for your project (e.g. my_awesome_project - recommendation is to use all lowercase and underscores separation for repo names.)
  2. Wait until the first run of CI finishes (Gitea Actions will process the template and commit to your new repo)
  3. Read the file CONTRIBUTING.md
  4. Then clone your new project and happy coding!

Note

: WAIT until first CI run on gitea actions before cloning your new project.

What is included on this template?

  • 🖼️ Templates for starting multiple application types: Run make init after cloning to generate a new project based on a template.
  • 📦 A basic setup.py file to provide installation, packaging and distribution for your project.
    Template uses setuptools because it's the de-facto standard for Python packages, you can run make switch-to-poetry later if you want.
  • 🤖 A Makefile with the most useful commands to install, test, lint, format and release your project.
  • 📃 Documentation structure using mkdocs
  • 💬 Auto generation of change log using gitchangelog to keep a HISTORY.md file automatically based on your commit history on every release.
  • 🐋 A simple Containerfile to build a container image for your project.
    Containerfile is a more open standard for building container images than Dockerfile, you can use buildah or docker with this file.
  • 🧪 Testing structure using pytest
  • Code linting using flake8
  • 🎯 Entry points to execute your program using python -m <project_name> or $ project_name with basic CLI argument parsing.
  • 🔄 Continuous integration using Gitea Actions with jobs to lint, test and release your project on Linux, Mac and Windows environments.

Curious about architectural decisions on this template? read ABOUT_THIS_TEMPLATE.md


project_name

project_description

Usage

from project_name import BaseClass
from project_name import base_function

BaseClass().base_method()
base_function()
$ python -m project_name
#or
$ project_name

Development

Read the CONTRIBUTING.md file.