Skip to main content

Awesome dstool created by xzyaoi

Project description

Python Project Template

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

See also

  • Flask-Project-Template for a full feature Flask project including database, API, admin interface, etc.
  • FastAPI-Project-Template The base to start an openapi project featuring: SQLModel, Typer, FastAPI, JWT Token Auth, Interactive Shell, Management Commands.

HOW TO USE THIS TEMPLATE

DO NOT FORK this is meant to be used from Use this template feature.

  1. Click on Use this template
  2. Give a name to your project
    (e.g. my_awesome_project recommendation is to use all lowercase and underscores separation for repo names.)
  3. Wait until the first run of CI finishes
    (Github Actions will process the template and commit to your new repo)
  4. If you want codecov Reports and Automatic Release to PyPI
    On the new repository settings->secrets add your PYPI_API_TOKEN and CODECOV_TOKEN (get the tokens on respective websites)
  5. Read the file CONTRIBUTING.md
  6. Then clone your new project and happy coding!

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

What is included on this template?

  • 🖼️ Templates for starting multiple application types:
    • Basic low dependency Python program (default) use this template
    • Flask with database, admin interface, restapi and authentication use this template. or 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
  • 📊 Code coverage reports using codecov
  • 🛳️ Automatic release to PyPI using twine and github actions.
  • 🎯 Entry points to execute your program using python -m <dstool> or $ dstool with basic CLI argument parsing.
  • 🔄 Continuous integration using Github 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
If you want to contribute to this template please open an issue or fork and send a PULL REQUEST.

❤️ Sponsor this project


dstool

codecov CI

Awesome dstool created by xzyaoi

Install it from PyPI

pip install dstool

Usage

from dstool import BaseClass
from dstool import base_function

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

Development

Read the CONTRIBUTING.md file.

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

dstool-0.1.0rc0.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

dstool-0.1.0rc0-py3-none-any.whl (10.8 kB view details)

Uploaded Python 3

File details

Details for the file dstool-0.1.0rc0.tar.gz.

File metadata

  • Download URL: dstool-0.1.0rc0.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for dstool-0.1.0rc0.tar.gz
Algorithm Hash digest
SHA256 d0ab8d8cfb6621d6b12f2f5bc6925a25726b926a3e3d19c888824cb3ab0456b5
MD5 3aed0728dfc14121836757943abcdce2
BLAKE2b-256 559fbfe94fce6d4d3a8b0bcf536ee605787c241a80a98470dd667a5f64bd6764

See more details on using hashes here.

File details

Details for the file dstool-0.1.0rc0-py3-none-any.whl.

File metadata

  • Download URL: dstool-0.1.0rc0-py3-none-any.whl
  • Upload date:
  • Size: 10.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for dstool-0.1.0rc0-py3-none-any.whl
Algorithm Hash digest
SHA256 b32cee0fe882ea3a097cf97e64484060006d1f0c0647e6972a42b0e7f70c0d54
MD5 937bd063602e9e32cac977b229f83ce8
BLAKE2b-256 aa0d6a3280aba296f4a1f9e09a699d6bff50a8087d72063fb9dd3f606f2725a0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page