python-c 1.0

Last updated:

0 purchases

python-c 1.0 Image
python-c 1.0 Images
Add to Cart

Description:

pythonc 1.0

python-c
An alternative to python -c with much less typing, at the price of being dirtier.
Installation:
$ pip install python-c


Usage
If you have a file named foo.py with:
def quite():
return 5
def loud():
print 'hello'
def double(arg):
return arg*2
Instead of:
$ python -c "import foo; foo.loud();"
hello
You can now write:
$ python-c foo 'loud()'
hello
You can load multiple files:
$ python-c foo,foo2 'loud()'
hello
or directories:
$ python-c ./,./dir1,./dir2/test.py 'loud()'
hello
In cases where it works (e.g clashes between files are benign), you can minimize your typing and omit the first argument, the current directory is then loaded by default:
$ python-c 'loud()'
hello


Printing
Printing is handled for you:
$ python-c foo 'quite()'
5
The result of the call (if any) is printed, even though the function does not call ‘print’.


More examples
You can pass arguments to your functions:
$ python-c foo 'double(2)'
4
You can execute arbitrary code in your single line:
$ python-c foo '"hot" if double(2) == 4 else "cold"'
hot
This includes printing:
$ python-c foo.py 'print "double {} is {}".format(2, double(2))'
double 2 is 4


Rationale
Time is our most valuable non-possesion. The python interpreter must be clean and unambiguous, including the way it handls it’s option ‘-c’. However, more often than not, I will accept being dirty (e.g live with benign clashes between files) and simply type python-c ‘test23()’ as opposed to the double as long python -c ‘import foo.py; foo.test23()’. Such dirty functionality should not be built into the interpreter, hence python-c: the tool playfully indicates its motivation by saving you from typing a space between ‘python’ and ‘-c’.

License:

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Customer Reviews

There are no reviews.