Turn functions into command-line interfaces
Project description
Clize procedurally turns your functions into convenient command-line interfaces.
For instance:
from clize import run
def hello_world(name=None, *, no_capitalize=False):
"""Greets the world or the given name.
name: If specified, only greet this person.
no_capitalize: Don't capitalize the given name.
"""
if name:
if not no_capitalize:
name = name.title()
return 'Hello {0}!'.format(name)
return 'Hello world!'
if __name__ == '__main__':
run(hello_world)
The python code above can now be used on the command-line as follows:
$ pip install clize
$ python3 hello.py --help
Usage: hello.py [OPTIONS] name
Greets the world or the given name.
Positional arguments:
name If specified, only greet this person.
Options:
--no-capitalize Don't capitalize the given name.
Other actions:
-h, --help Show the help
$ python3 hello.py
Hello world!
$ python3 hello.py john
Hello John!
$ python3 hello.py dave --no-capitalize
Hello dave!
You can find the documentation at: http://clize.readthedocs.io/
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
clize-4.0b1.tar.gz
(62.9 kB
view hashes)
Built Distribution
clize-4.0b1-py2.py3-none-any.whl
(68.8 kB
view hashes)
Close
Hashes for clize-4.0b1-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7f035a2f902d163993cf7a04c0bb5f7e03ebe8ff9239042da85489fb9956f1f2 |
|
MD5 | 7e4ebbd0f3e8cbb9c71822c6f0962e2d |
|
BLAKE2b-256 | b253087dcff7d31549aa336b4b0bbefb6bb94ed3843467abc698a76e0a9b34db |