A tool for keeping track of Python's interactions with the shell.
Project description
NOTICE: After using this package for a few years, we realized we'd attempted to do too many things at once with it. It still provides tremendous functionality for a wide variety of use cases, but for particular corner cases, it became apparent that design decisions made early on were hampering forward progress, and we wouldn't recommend doing things the same way today. Certain aspects of its functionality have inspired more focused packages (reverse-argparse, staged-script), and we hope to do the same with more functionality in the future. For the time being, though, don't expect much development and maintenance here. That said, if you use
shell-logger
and are eager to contribute to its longevity, let us know.
shell-logger
The shell-logger
Python package allows you to interact with the shell, while
logging various metadata, statistics, and trace information. Any time you're
tempted to write your own wrapper around things like subprocess.Popen()
or
subprocess.run()
, consider using shell_logger.ShellLogger.log()
instead.
If you're familiar with the Unix script command, this is similar in
principle, but with substantially more functionality. If you're familiar with
Python's logging module, the motivation is similar, but this intends
to capture what's happening in the shell rather than in Python itself.
Installation
To get up and running with shell-logger
, simply:
python3 -m pip install shell-logger-sandialabs
Usage
Once the package is installed, you can simply
from shell_logger import ShellLogger
sl = ShellLogger("Title of Log File")
sl.log("Execute my first command in the shell.", "echo 'Hello World'")
sl.finalize()
For more detailed usage and API information, please see our documentation.
Where to Get Help
If you're having trouble with shell-logger
, or just want to ask a question,
head on over to our issue board. If a quick search doesn't yield
what you're looking for, feel free to file an issue.
Contributing
If you're interested in contributing to the development of shell-logger
, we'd
love to have your help :grinning: Check out our
contributing guidelines for how to get started.
Past contributors include:
License & Copyright
See LICENSE.md and COPYRIGHT.md.
Credits
Special thanks to the EMPIRE project for investing in the initial development of this tool, and the GMS project for serving as a second user and contributing to its clean-up.
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
Built Distribution
File details
Details for the file shell_logger_sandialabs-1.0.4.tar.gz
.
File metadata
- Download URL: shell_logger_sandialabs-1.0.4.tar.gz
- Upload date:
- Size: 175.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b8e57310735a9cee88ee5972e5ca5ab04ecd3a3900e9772070b5b1b7e04f07a7 |
|
MD5 | 8ec6316acec0acab05d9c930d85a29b8 |
|
BLAKE2b-256 | 1b2014d4dd7e72625a87c93a01a55976bed89be91724b340f7b868f9ab0a91e2 |
File details
Details for the file shell_logger_sandialabs-1.0.4-py3-none-any.whl
.
File metadata
- Download URL: shell_logger_sandialabs-1.0.4-py3-none-any.whl
- Upload date:
- Size: 183.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2c88d3314553919f3ef2c066708639faba4bd7cdb5bed8db1745b7c065c1f571 |
|
MD5 | da071c2edd5c590d693328cc1752ca30 |
|
BLAKE2b-256 | b20e189e1812169f3f8b88e32dcaf1fe831f93a95e3628ac39980a0d0d468285 |