Simple command line commands through decorators
Project description
Commandify
Allows simple creation of Python command line utilities through decorating functions. Builds on the argparse module in the standard library. Optionally uses the argcomplete module to provide command line tab-completion for bash/zsh.
Installation
pip install commandify
Running example and usage
Once commandify has been installed, it can be run with:
commandify_examples --help
commandify_examples code:
#!/usr/bin/env python
# Only required if you want to use argcomplete:
# PYTHON_ARGCOMPLETE_OK
'''Examples of a simple set of functions that use commandify
usage::
commandify_examples --help
commandify_examples <command> --help
commandify_examples --main-arg=22 <command>
commandify_examples -m=22 <command>
commandify_examples cmd_no_args
'''
from commandify import commandify, command, main_command
@main_command(main_arg={'flag': '-m'})
def main(main_arg=345):
'''Example of how to use commandify
Main command, called before any other command
Can be used to set any global variables before any other commands executed.
usage::
commandify_examples --help
commandify_examples --main-arg=22 cmd_no_args
commandify_examples -m=22 cmd_no_args
commandify_examples cmd_no_args
'''
print(type(main_arg))
print("Main command: {0}".format(main_arg))
@command
def cmd_no_args():
'''Simplest command
usage::
commandify_examples cmd_no_args
'''
print('cmd_no_args called')
@command
def cmd1(name):
'''Simple command with argument
usage::
commandify_examples cmd1 --name=a1
commandify_examples cmd1 --name a3
commandify_examples cmd1 --name 'a4'
'''
print('cmd1 running')
print(name)
@command(username={'flag': '-n'})
def cmd2(username, userid):
'''Command with 2 args and a short flag set for name
usage::
commandify_examples cmd2 --username=steve --userid=55
commandify_examples cmd2 -n=sarah --userid=56
'''
print('{0}: {1}'.format(userid, username))
@command(some_arg={'default': 377})
def cmd3(some_arg, arg_with_default='arg_default'):
'''Command with defaults set in two ways
first through decorator and second through function arguments.
usage::
commandify_examples cmd3
commandify_examples cmd3 --arg-with-default=default_overridden
'''
# Type of some_arg will be int:
print(type(some_arg))
print(some_arg, arg_with_default)
@command
def cmd4(some_arg=False):
'''Command with False bool default
usage::
commandify_examples cmd4
commandify_examples cmd4 --some-arg
'''
# Type of some_arg will be bool:
print(type(some_arg))
# If it is called specifying --some-arg, it will be True.
print(some_arg)
@command
def cmd5(some_arg=True):
'''Command with True bool default
Command line argument gets turned into negative to handle this.
usage::
commandify_examples cmd5
commandify_examples cmd5 --not-some-arg
'''
# Type of some_arg will be bool:
print(type(some_arg))
# If it is called without specifying --not-some-arg, it will be True.
print(some_arg)
@command
def cmd6():
print('cmd6 called')
if __name__ == '__main__':
try:
import argcomplete
commandify(suppress_warnings=['default_true'], use_argcomplete=True)
except ImportError:
commandify(suppress_warnings=['default_true'])
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
commandify-0.0.4.10.tar.gz
(138.4 kB
view details)
Built Distribution
File details
Details for the file commandify-0.0.4.10.tar.gz
.
File metadata
- Download URL: commandify-0.0.4.10.tar.gz
- Upload date:
- Size: 138.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e2e17453c62e49017c2c734835746bbecaff1e12dff244e731445886963ecadf |
|
MD5 | b039992f229caaf50ee337991730e816 |
|
BLAKE2b-256 | 49004a7f4ee0d78594a8102a3fc62e95b80290ab3b8a7dedc52295728d4fca90 |
File details
Details for the file commandify-0.0.4.10-py2-none-any.whl
.
File metadata
- Download URL: commandify-0.0.4.10-py2-none-any.whl
- Upload date:
- Size: 11.3 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3dd3b8f84b3cd68610ee64597fbf03085b47e64631b5566a58cb89be425b83c7 |
|
MD5 | 404939a78915a36ab6d0b78f84eb61db |
|
BLAKE2b-256 | 788a08eb341c2764564c1783cca82e91d0d5c17ecdf9370fa0846c823f565f1b |