Skip to main content

Helper For Capturing Text IO Streams like stdout, stderr

Project description

TextIOTrap

Simple class for trapping / capturing Python Text IO streams like from subprocess.popen, pexpect, sys.stderr and others; enabling the capture output of or dropping streams with cross platform DEVNULL helper.

Installation

python3 -m pip install tiotrap

Usage

This tool contains one class TextIOTrap and a helper DEVNULL.

Examples

(Ex1) Use TextIOTrap to capture stdout of a chatty process using store option:

_stdout_bk = sys.stdout # Store original stdout
ttrap = tiotrap.TextIOTrap(store=True)

try:
    sys.stdout = ttrap # Map stdout to tiotrap
    print("TEST1")
    # call some chatty functions()
    print("TEST2")

finally:
    sys.stdout = _stdout_bk # Restore stdout

Output of print:

captured logs:
TEST1
<chatty outputs here>
TEST2

(Ex2) Use TextIOTrap to capture stdout using write_handler option:

aTrap = []
_stdout_bk = sys.stdout
try:
    sys.stdout = tiotrap.TextIOTrap(write_handler=lambda s: aTrap.append(s))
    print("TEST1")
    print("TEST2")

finally:
    sys.stdout = _stdout_bk
# print adds extra \n end so remove with rstrip()
print(f"aTrap:\n{''.join(aTrap).rstrip()}\n~end~\n")

Output of print:

aTrappedStdout = ['TEST1', 'TEST2']

You can substitute lambda with a function or method call to handle writes with your own code.

(Ex3) Use TextIOTrap grab output pexpect call :

ttrap = tiotrap.TextIOTrap(store=True)

p = pexpect.spawn('ls -la')
p.logfile = ttrap
p.expect(pexpect.EOF)

print(f"`ls -la` cmd output:\n{ttrap.entries()}\n~")

Output of print:

ls output:
<full directory listing here of cwd>

Other uses of TextIOTrap:

  • Output the stdout of a subprocess.popen call in real time to a secondary log file
  • ...

(Ex4) Use TextIOTrap grab output pexpect call :

ttrap = tiotrap.TextIOTrap(store=True)

p = pexpect.spawn('ls -la')
p.logfile = ttrap
p.expect(pexpect.EOF)

print("ls -la` cmd output (as was written):")
for write in ttrap:
    print(write)

Output: Similar to Ex4

(Ex5) Use DEVNULL to drop all output of a TextIO Stream

_stdout_bk = sys.stdout

try:
    sys.stdout = tiotrap.DEVNULL
    print("THIS WILL NOT PRINT")

finally:
    sys.stdout = _stdout_bk

print("THIS WILL PRINT")

This DEVNULL is very simple implementation and is fully cross platform unlike someother DEVNULL implementations.

Note: TextIOTrap has been set up to be compatible with the standard methods for a Text IO streams. I'll be glad to update if any edge cases are discovered.

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

tiotrap-0.3.3.tar.gz (4.1 kB view details)

Uploaded Source

Built Distribution

tiotrap-0.3.3-py3-none-any.whl (4.1 kB view details)

Uploaded Python 3

File details

Details for the file tiotrap-0.3.3.tar.gz.

File metadata

  • Download URL: tiotrap-0.3.3.tar.gz
  • Upload date:
  • Size: 4.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.7.9 Linux/5.13.0-37-generic

File hashes

Hashes for tiotrap-0.3.3.tar.gz
Algorithm Hash digest
SHA256 b1b2b1c3dabc2800725ab34d256c9c6d03cde4e759688471f6120a09f047831e
MD5 080cf4dd38824d0673c13717cf22f7f7
BLAKE2b-256 c4ba8789b170a6d288c29f8f257443fbec5b2bee2118bd3da7b76bb5dff79b42

See more details on using hashes here.

File details

Details for the file tiotrap-0.3.3-py3-none-any.whl.

File metadata

  • Download URL: tiotrap-0.3.3-py3-none-any.whl
  • Upload date:
  • Size: 4.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.7.9 Linux/5.13.0-37-generic

File hashes

Hashes for tiotrap-0.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ae021469ead5e7aafcb84223796472bbba2637563988695600fcd8821e7e9c9c
MD5 08acfc8ef2f8b713be7ac6e7079a01da
BLAKE2b-256 b47bfc9b4e7625e18e096f5738b6703c998aed1822d13ee68b5633e30e584b1b

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