Skip to main content

Adds a utility for running pyss.yaml files.

Project description

PySS: Python Script Support Tool

Sponsor Me! PyPI version GitHub license Downloads Downloads

PySS is a tool designed to facilitate the management and execution of pyss.yaml configurations, aimed at enhancing Python scripting workflows. It offers a straightforward command-line interface for executing scripts defined in a pyss.yaml or pyss.yml file, with capabilities for testing configurations, silent and quiet execution modes, and advanced configuration options including environment variables, custom variables, and pre/post execution scripts. The project is open-source, licensed under the MIT License, and is geared towards simplifying script execution tasks for Python developers

Installing PySS

To integrate PySS into your environment, simply run:

pip install pyss

How to Use

PySS streamlines script execution through a user-friendly command-line interface:

usage: pyss [options] [script_name]

A simple script runner for Python.

positional arguments:
  script_name    the name of the script to execute

options:
  -h, --help     show this help message and exit
  -l, --list     show a list of all scripts configured for use
  -t, --test     validate the pyss configuration file
  -s, --silent   execute the script without any output
  -q, --quiet    execute the script while omitting the [pyss] header messages
  -v, --version  prints the program version to stdout

To configure your project with PySS, create a pyss.yaml or pyss.yml file at the project root. This file should enumerate the commands you plan to execute.

Configuration Example

Below is a straightforward example to get you started:

# Configure PySS settings here (all optional).
pyss:
 min_version: 1.0.2
 max_version: 1.1.7

# List your executable scripts.
scripts:
  - name: say-my-name
    description: Outputs a predetermined name
    command: echo Heisenberg

Execute a script by invoking the pyss command at your project's root:

$ pyss say-my-name
[pyss][run script] 'say-my-name'
[pyss][os.system] 'echo Heisenberg'
Heisenberg

Advanced Configuration

For more complex setups, PySS supports environment variables, custom variables, pre/post execution scripts, per-platform customization, shell customization and internal script designation. View the Advanced Configuration documentation for more information.

Validating Your Configuration

To ensure your configuration is valid, run the following command:

$ pyss --test
[pyss][validate] Validating configuration file 'pyss.yaml'...
[pyss][validate] Configuration file 'pyss.yaml' is valid.

Running Scripts

Verbose Execution (Default)

$ export AGE=28
$ pyss run
[pyss][run script] run
[pyss][run script] print-greeting
[pyss][os.system] echo Hello, ${NAME}!
Hello, Heisenberg!
[pyss][os.system] echo Your name is ${NAME}
Your name is Heisenberg
[pyss][os.system] echo You are ${AGE} years old.
You are 28 years old.
[pyss][run script] print-farewell
[pyss][os.system] echo Goodbye, ${NAME}!
Goodbye, Heisenberg!

Quiet Mode (--quiet)

$ export AGE=28
$ pyss --quiet run
Hello, Heisenberg!
Your name is Heisenberg
You are 28 years old.
Goodbye, Heisenberg!

Silent Mode (--silent)

# This mode executes the script without producing any output.

Additional Features

To view a list of configured scripts, use:

$ pyss --list

Credits

Special thanks to Pyss Man: @mavrw

License

This project is licensed under the MIT License - see the LICENSE file for details.

Project details


Download files

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

Source Distribution

pyss-1.1.7.tar.gz (11.8 kB view details)

Uploaded Source

Built Distribution

pyss-1.1.7-py3-none-any.whl (11.2 kB view details)

Uploaded Python 3

File details

Details for the file pyss-1.1.7.tar.gz.

File metadata

  • Download URL: pyss-1.1.7.tar.gz
  • Upload date:
  • Size: 11.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.3

File hashes

Hashes for pyss-1.1.7.tar.gz
Algorithm Hash digest
SHA256 d921156b4cb6476ecf488bfd3e7da78f70ab2c4578dedd8e2618bf63e802a63e
MD5 4f76fe163e0107a7fd0eff702ecc8edd
BLAKE2b-256 8a29cdf151f2b7fe39d59aa8e10bc40d629667d1e8e0fabb81aebdd591f5973f

See more details on using hashes here.

File details

Details for the file pyss-1.1.7-py3-none-any.whl.

File metadata

  • Download URL: pyss-1.1.7-py3-none-any.whl
  • Upload date:
  • Size: 11.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.3

File hashes

Hashes for pyss-1.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 fbf6acd3d8f3aee52865907ccf9f784af790de972b55bae91604df550a006878
MD5 b90ff35dd5373a3ddb139301a81c88b4
BLAKE2b-256 caaa7f7c46b420c83bc5d5c5bcb861a2e4a63b712a4f09a5c30c7673487d5e7e

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