Skip to main content

Python subprocess replacement

Project description

Logo Version Downloads Status Python Versions Coverage Status

sh is a full-fledged subprocess replacement for Python 3.8 - 3.14, and PyPy that allows you to call any program as if it were a function:

from sh import git
print(git("status", "--short"))

sh is not a collection of system commands implemented in Python.

sh relies on various Unix system calls and only works on Unix-like operating systems - Linux, macOS, BSDs etc. Specifically, Windows is not supported.

Complete documentation here

Full documentation on a single page for LLM-assisted coding here

Installation

$> pip install sh

Support

Developers

Testing

Tests are run in a docker container against all supported Python versions. To run, make the following target:

$> make test

To run a single test:

$> make test='FunctionalTests.test_background' test_one

Docs

To build the docs, make sure you’ve run poetry install to install the dev dependencies, then:

$> cd docs
$> make html

This will generate the docs in docs/build/html. You can open the index.html file in your browser to view the docs.

Coverage

First run all of the tests:

$> SH_TESTS_RUNNING=1 coverage run --source=sh -m pytest

This will aggregate a .coverage. You may then visualize the report with:

$> coverage report

Or generate visual html files with:

$> coverage html

Which will create ./htmlcov/index.html that you may open in a web browser.

Download files

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

Source Distribution

sh-2.2.5.tar.gz (43.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sh-2.2.5-py3-none-any.whl (43.9 kB view details)

Uploaded Python 3

File details

Details for the file sh-2.2.5.tar.gz.

File metadata

  • Download URL: sh-2.2.5.tar.gz
  • Upload date:
  • Size: 43.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sh-2.2.5.tar.gz
Algorithm Hash digest
SHA256 0fbd42f1e8b11663c4a5f7b14f9ce860eb7a7a17167fe022a66b1295de6e7396
MD5 a646d41acc1f59d138a4bc6996d607da
BLAKE2b-256 a0763bc4fcf2dec19f9e515545bac706d30b9ff3293fcb03da84ac4463e94321

See more details on using hashes here.

Provenance

The following attestation bundles were made for sh-2.2.5.tar.gz:

Publisher: main.yml on amoffat/sh

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sh-2.2.5-py3-none-any.whl.

File metadata

  • Download URL: sh-2.2.5-py3-none-any.whl
  • Upload date:
  • Size: 43.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sh-2.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 8843c51f1c76f2f373b2ed0ee00a6642d0d64eded8edb79671db78bfdc521bea
MD5 2aaa225fe8704a09654730e60eb9fdbf
BLAKE2b-256 8a31e58e6cd1b1524b4929d3d63ea420758efc018cd1356d81c5d07cbc8f1324

See more details on using hashes here.

Provenance

The following attestation bundles were made for sh-2.2.5-py3-none-any.whl:

Publisher: main.yml on amoffat/sh

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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