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.
- Click on Use this template
- Give a name to your project
(e.g.my_awesome_project
recommendation is to use all lowercase and underscores separation for repo names.) - Wait until the first run of CI finishes
(Github Actions will process the template and commit to your new repo) - If you want codecov Reports and Automatic Release to PyPI
On the new repositorysettings->secrets
add yourPYPI_API_TOKEN
andCODECOV_TOKEN
(get the tokens on respective websites) - Read the file CONTRIBUTING.md
- 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 runmake 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.
dstool
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
Release history Release notifications | RSS feed
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)
Built Distribution
dstool-0.1.0rc0-py3-none-any.whl
(10.8 kB
view details)
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | d0ab8d8cfb6621d6b12f2f5bc6925a25726b926a3e3d19c888824cb3ab0456b5 |
|
MD5 | 3aed0728dfc14121836757943abcdce2 |
|
BLAKE2b-256 | 559fbfe94fce6d4d3a8b0bcf536ee605787c241a80a98470dd667a5f64bd6764 |
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | b32cee0fe882ea3a097cf97e64484060006d1f0c0647e6972a42b0e7f70c0d54 |
|
MD5 | 937bd063602e9e32cac977b229f83ce8 |
|
BLAKE2b-256 | aa0d6a3280aba296f4a1f9e09a699d6bff50a8087d72063fb9dd3f606f2725a0 |