 
Scaffolding templates for your Python project.
create a blank python package that is usable and ready to push to github. And future updates on your organisation's specific static information can be instantly applies the update accurately using `moban`_. Here is a list of features:
- core python package
- test configuration setup
- ready to commit github repository
- automated upload to pypi via github actions
- version management through jinja2
- automatic extraction of github contributors
- semi-automatic change log generation
It is used with yehua. Organisations using it:
The following table is a personal feature comparision. If you have a different opinion, especially you are the author of the following repository, please raise an issue and we can talk. This table is not a commerical sales pitch.
- Y: have such a feature
- M: manual operation
- A: automatic operation
| Group | Feature | cookiecutter-pypackage | cookiecutter-vanguard | PyScaffold | yehua | 
|---|---|---|---|---|---|
| essential | setup.py | Y | Y | Y | Y | 
| . | setup.cfg | Y | Y | Y | Y | 
| . | source code stub | Y | Y | Y | Y | 
| test setup | requirements.txt | Y | Y | Y | |
| . | requirements_dev.txt | Y | Y | Y | |
| . | Makefile | Y | Y | ||
| . | tests code | Y | Y | Y | |
| . | tox | Y | Y | ||
| . | travis | Y | Y | Y | |
| . | test coverage | Y | Y | ||
| . | flake8 | Y | |||
| documentation | README.rst | Y | Y | Y | |
| . | labels | Y | |||
| . | gitignore | Y | Y | Y | |
| . | AUTHORS.rst | Y | Y | Y | |
| . | CONTRIBUTING.rst | Y | Y | ||
| . | HISTORY.rst/CHANGELOG .rst | Y | Y | Y | Y | 
| . | LICENCE | Y | Y | Y | Y | 
| . | MANIFEST.in | Y | Y | Y | |
| . | sphinx docs | Y | Y | Y | Y | 
| usability | interactive shell | Y | Y | Y | |
| . | one liner | Y | |||
| . | initialize github repo | Y | |||
| maintenance | publish on pypi | A | M | M | |
| . | dependency management | M | M | A | |
| . | template customization | Y | |||
| . | version management | M | M | A | |
| . | automated github release | Y | |||
| . | continous templating | Y | 
- flake8 compliant setup.py
- feature parity with kennethreitz/setup.py- automatically upload to pypi without using twine
- automatically do git release while uploading to pypi
 
- configured to build universial wheels by default
4. comes with a feature of removing comments from requirements.txt while loading into setup.py
You can get it:
$ git clone https://github.com/moremoban/pypi-mobans.git
$ cd pypi-mobansPlease fork and make pull request to dev branch. Per each release, dev branch will be merged into master branch.
In order to make moban updates: please call make.
In order to configure github to publish your package, you will need to set up two secrets:
PYPI_USERNAME PYPI_PASSWORD
Once you have done that, a github release will trigger an auto publishing.
The following strings are required in your project yaml file:
python_requires: ">=3.6" min_python_version: "3.6"
In order to use dependency markers in setup.py, add setup_use_markers: true in your `mobanfile.
You can specify excluded_github_users to exclude yourself and bot accounts.
In order to update this README, please find the .moban.d/local-README.rst.jj2, and place your changes there.
Then call:
$ make upstreaming