Skip to main content

A tool designed to retrieve messages from the IOPub channel of a Jupyter kernel using jupyter_client, capturing cell outputs and logs.

Project description

Swamauri Logo

PyPI - Downloads GitHub Hits PyPI - Python Version PyPI - License
PyPI - swarmauri_tool_jupytergetiopubmessage


swarmauri_tool_jupytergetiopubmessage

A Python tool designed to retrieve messages from the IOPub channel of a Jupyter kernel using jupyter_client, capturing cell outputs, logging information, and errors.

Installation

To install swarmauri_tool_jupytergetiopubmessage, make sure you have Python 3.10 or later. You can install the latest release from PyPI using:

pip install swarmauri_tool_jupytergetiopubmessage

Verify the installation by opening a Python shell and importing the module:

python

import swarmauri_tool_jupytergetiopubmessage print(swarmauri_tool_jupytergetiopubmessage.version) '0.1.0.dev1'

If you see a valid version number, the package is installed and ready to use.

Usage

Below is a brief example of how to use JupyterGetIOPubMessageTool to capture messages from an active Jupyter kernel. In most scenarios, you will have a running Jupyter kernel and a kernel client available.


Example usage:

from jupyter_client import KernelManager from swarmauri_tool_jupytergetiopubmessage import JupyterGetIOPubMessageTool

Initialize a new Jupyter kernel

km = KernelManager() km.start_kernel() kc = km.client() kc.start_channels()

Execute a sample command in the kernel to produce some output

kc.execute("print('Hello from the kernel!')")

Initialize and use the JupyterGetIOPubMessageTool

tool = JupyterGetIOPubMessageTool() result = tool(kernel_client=kc, timeout=3.0)

print("Captured stdout:", result["stdout"]) print("Captured stderr:", result["stderr"]) print("Captured logs:", result["logs"]) print("Execution results:", result["execution_results"]) print("Did timeout occur?:", result["timeout_exceeded"])

Clean up kernel resources

kc.stop_channels() km.shutdown_kernel()


This usage example demonstrates how to retrieve stdout messages, stderr messages, logs (including certain non-stream messages), and results from executed cells. The timeout parameter controls how long the tool waits for IOPub messages before returning. If the time is exceeded, "timeout_exceeded" will be True.

Dependencies

• Python 3.10 to 3.13
• jupyter_client
• swarmauri_core (for component registration)
• swarmauri_base (for the base tool functionality)

Additional development dependencies (e.g., flake8, pytest) are specified in the pyproject.toml file but not required for basic usage.

Building & Testing

This package uses Poetry for its build system. You may use any standard Python tooling to install and test in your environment. See above Installation instructions for installing into your project.


© 2023 Swarmauri. All rights reserved. This project is licensed under the Apache-2.0 License. Use of this tool is governed by the license conditions included in the repository.

Project details


Release history Release notifications | RSS feed

This version

0.7.0

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

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

File details

Details for the file swarmauri_tool_jupytergetiopubmessage-0.7.0.tar.gz.

File metadata

File hashes

Hashes for swarmauri_tool_jupytergetiopubmessage-0.7.0.tar.gz
Algorithm Hash digest
SHA256 55a18e51a57e378337ce2382b63c64a88c61c2a68a06982f95376d162e1e97ac
MD5 818d7a4b58cc40a4a7c2b910b1422ea0
BLAKE2b-256 04d644ab34fa82b5a2f7b8e124d2deb1e03976689a98ec1ab61bea4a71ea414b

See more details on using hashes here.

File details

Details for the file swarmauri_tool_jupytergetiopubmessage-0.7.0-py3-none-any.whl.

File metadata

File hashes

Hashes for swarmauri_tool_jupytergetiopubmessage-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 af869e03c0daebd030f5fb3e3f5e7ae54cbf0b9efb469500293501d9cc48e926
MD5 17a0c659c50472e8ac84bb79836841d3
BLAKE2b-256 246d4e11a59536e37e8f2a3fdaa2551bc68d42f7aa5c04c0e8f45603704fec05

See more details on using hashes here.

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