Capture C-level output in context managers
Project description
Wurlitzer
Capture C-level stdout/stderr pipes in Python via os.dup2
.
For more details on why this is needed, please read this blog post.
Install
pip install wurlitzer
Usage
Capture stdout/stderr in pipes:
from wurlitzer import pipes with pipes() as (out, err): call_some_c_function() stdout = out.read()
Capture stdout/stderr in StringIO:
from io import StringIO from wurlitzer import pipes, STDOUT out = StringIO() with pipes(stdout=out, stderr=STDOUT): call_some_c_function() stdout = out.getvalue()
Forward C-level stdout/stderr to Python sys.stdout/stderr, which may already be forwarded somewhere by the environment, e.g. IPython:
from wurlitzer import sys_pipes with sys_pipes(): call_some_c_function()
Or even simpler, enable it as an IPython extension:
%load_ext wurlitzer
To forward all C-level output to IPython during execution.
Acknowledgments
This package is based on stuff we learned with @takluyver and @karies while working on capturing output from the Cling Kernel for Jupyter.
Wurlitzer?!
Wurlitzer makes pipe organs. Get it? Pipes? Naming is hard.
Project details
Release history Release notifications | RSS feed
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
Hashes for wurlitzer-3.0.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 37f3ed1b08bf887172eda7f5177417241ec54cdd5e70df74c92d96875ceff632 |
|
MD5 | 806c9969be7469165a3b9aa561492920 |
|
BLAKE2-256 | d3164ed932c896808eae84ad92ea62dcfd5c8433b36fdd00dfc38b213abde178 |