Skip to main content

Shell scripting library for Python

Project description

pyscripting is python module that provides various utilities to make shell scripting with python easier.

Getting started

  1. Get scripting.py:

    pip install pyscripting
  2. Create your python shell script myscript.py:

    #!/usr/bin/env python
    
    from scripting import sh
    
    sh.ls('-l')
  3. Use your script:

    chmod +x myscript.py
    ./myscript.py

Calling external commands

There are three ways to call external commands.

If possible, python replacement of an external command will be used. Replacements will not be used only in direct calling.

For all replaced commands see Replaced commands.

Direct calling

Returns exit code.

sh('ls', '-l')

Indirect calling

Returns exit code.

sh.ls('-l')

Call and return output

Returns stripped stdout (stderr will not be included).

Using this method, output of command will not be printed to stdout. Before returning output, leading white spaces will be stripped.

Don’t use this methos for large outputs.

output = sh.get('ls', '-l')
print('Output was: %s' % output)

Argument handling

You can access arguments passed to script using argv property:

sh.argv[0] - called script name
sh.argv[1] - first argument

Replaced commands

To avoid overhead and for simplicity reasons, some external commands was replaced by python’s internal functions, which works much faster, that calling external command.

basename

Same as external basename.

Returns string.

exit

Same as external exit.

find

Similar to external find command.

Returns iterator of all found files.

Example usage:

for f in sh.find(type='f', exclude=['*.pyc']):
    print(f)
mkdir

Same as external mkdir.

mkdirs

Same as external mkdir -p.

test

Similar to external test.

Returns boolean.

Example usage:

if sh.test('-d', '/tmp'):
    print('/tmp is directory.')

Makefile functionality

Example (myscript.py):

#!/usr/bin/env python

from scripting import sh, Makefile

make = Makefile(sh)


@make('/tmp/myfile.txt')
def myrule(target):
    sh.touch(target)

@make()
def main(target):
    myrule()

make.run(main)

Last line make.run(main) checks sys.argv and executes specified rule or default if no particular rule is specified. myrule will be executed only, if target file /tmp/myfile.txt does not exists.:

./myscript.py

Now call particular rule:

./myscript.py myrule

Project details


Release history Release notifications | RSS feed

This version

0.1

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyscripting-0.1.tar.gz (3.6 kB view details)

Uploaded Source

Built Distribution

pyscripting-0.1.linux-x86_64.exe (68.1 kB view details)

Uploaded Source

File details

Details for the file pyscripting-0.1.tar.gz.

File metadata

  • Download URL: pyscripting-0.1.tar.gz
  • Upload date:
  • Size: 3.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for pyscripting-0.1.tar.gz
Algorithm Hash digest
SHA256 481d88a58f370b9336891d1bdfa7774c3b670eba98d7ef9f408f16c6a0fbc20c
MD5 423de0a56d95ee7db33b32df0ac9621f
BLAKE2b-256 fc3adf746b5d9ffe287dd21872d3fab845c0056dad33ffc82d391180e07a4b36

See more details on using hashes here.

File details

Details for the file pyscripting-0.1.linux-x86_64.exe.

File metadata

File hashes

Hashes for pyscripting-0.1.linux-x86_64.exe
Algorithm Hash digest
SHA256 a7a165e17e308fc0a0e9be4f17b3600f4fdc4c58fd70ae05d7fbf94f91aa8365
MD5 73941cd16ad7e8152dda6b92623878a5
BLAKE2b-256 5c821d7cee0cc614a9fd7c5c8ec3eba64720dbf4c8565618c4022f07a061e480

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page