/python-cli-skeleton

Python argparse skeleton

Primary LanguagePythonMIT LicenseMIT

Build Status Coverage Status

python-cli-skeleton

A simple python command line interface skeleton project. Features support for:

  • travis-ci
  • coveralls
  • argparse
  • py.test (testing)

Installation

python setup.py install 

For development, use:

python setup.py develop

...and the program will be installed in-place, allowing you to edit the script files and test them from the command line.

Usage

The setup script will install the program as cli. You can invoke it using:

cli

To change the way the program is invoked, edit the cli/__init__.py file where you can set the __version__ and _program variables. The _program variable sets the commandline command (cli), and the program name. You may want to change the names of modules (folders) as well to reflect your program. You should change the entry_point part of the setup script to reflect any changes you make to folders/files:

entry_points="""
[console_scripts]
{program} = cli.cli:main
""".format(program = _program),

requirements.txt

Add any modules you want installed to the requirements.txt file. The setup file parses this file before installation. Currently, [clint](https://github.com/kennethreitz/clint) is the only requirement. It is a useful module for adding color, indenting, progress bars, and other useful things to command-line based programs.

travis-ci

A .travis.yml file is included and setup for Python. Testing is performed using Python 2.7 and 3.6. You will need to setup [travis-ci.org](travis-ci.org) to perform testing.

coveralls

Support for coveralls is build in using pytest-cov. Please see coveralls.io for more information. You may want to edit the .coveragerc file to fine tune how coverage is calculated.