0 purchases
popen 0.1.20
popen
What is it?
The popen package provides a simple shell-like syntax inside python for running
external commands.
Features:
Chaining (aka. piping) as Sh('ls') | 'sort'
Redirect stderr to stdout as Sh('make').include_stderr | 'wc'
Redirect output to file as Sh('ls') > '~/listing.txt'
Iteration over output lines as for line in Sh('ls'):
Streaming input into commands in the chain as Sh.pipe('~/listing.txt').Sh('grep', '-q', 'code').returncode
Expands special characters (~*!?)
Expands env vars ($HOME) as print Sh('ls', '$USER', '~/*')
Properly splits strings ('echo "hole in one"' becomes ['echo', 'hole in one'])
Or iterable arguments (Sh('ls', '-l') | ['wc', '-l'] > '/dev/null')
TL;DR
Installation:
pip install popen
Example:
from popen import Sh
for line in Sh('du', '~/') | 'head -n 10' | 'sort -n':
print('GOT', line)
Usage
Simples usage, run a command and iterate the output lines:
from popen import Sh
for line in Sh('ls', '-la', '~'):
print line
Piping that output to a file:
Sh('ls', '-la', '~') > '~/listing'
Note that special characters like ~ are expanded, as are environment
variables (e.g. $HOME).
Chaining commands is trivial, here with append instead of write to file:
Sh('ls') | Sh('sort') >> '~/listing'
But the right hand side of | can be very flexible, as it employs
lexical splitter on string input or takes an iterable:
Sh('ls', '-la', '~') | 'sort -c' | ['uniq', '-c'] | 'tail' | Sh('wc') > '~/listing'
To run a command and let output go to stdout, ask for the return code:
cmd = Sh('ls') | 'grep polka'
print cmd.returncode
To pipe a string into a command, wrap in an iterable:
print Sh.pipe(['this is a \nmulti line\nstring.']) | 'wc'
For personal and professional use. You cannot resell or redistribute these repositories in their original state.
There are no reviews.