Skip to main content

No project description provided

Project description

Datalayer

Become a Sponsor

🪐 Jupyter NbModel Client

Github Actions Status PyPI - Version

Jupyter NbModel Client is a python library to interact with a live Jupyter Notebooks.

To install the library, run the following command.

pip install jupyter_nbmodel_client

We ask you to take additional actions to overcome limitations and bugs of the pycrdt library.

# Ensure you create a new shell after running the following commands.
pip uninstall -y pycrdt datalayer_pycrdt
pip install datalayer_pycrdt

Usage with Jupyter

  1. Ensure you have the needed packages in your environment to run the example here after.
pip install jupyterlab jupyter-collaboration matplotlib
  1. Start a JupyterLab server, setting a port and a token to be reused by the agent, and create a notebook test.ipynb.
# make jupyterlab
jupyter lab --port 8888 --ServerApp.port_retries 0 --IdentityProvider.token MY_TOKEN --ServerApp.root_dir ./dev
  1. Open a IPython (needed for async functions) REPL in a terminal with ipython (or jupyter console). Execute the following snippet to add a cell in the test.ipynb notebook.
from jupyter_nbmodel_client import NbModelClient, get_jupyter_notebook_websocket_url

ws_url = get_jupyter_notebook_websocket_url(
    server_url="http://localhost:8888",
    token="MY_TOKEN",
    path="test.ipynb"
)

async with NbModelClient(ws_url) as nbmodel:
    nbmodel.add_code_cell("print('hello world')")

Check test.ipynb in JupyterLab, you should see a cell with content print('hello world') appended to the notebook.

  1. The previous example does not involve kernels. Put that now in the picture, adding a cell and executing the cell code within a kernel process.
from jupyter_kernel_client import KernelClient
from jupyter_nbmodel_client import NbModelClient, get_jupyter_notebook_websocket_url

with KernelClient(server_url="http://localhost:8888", token="MY_TOKEN") as kernel:
    ws_url = get_jupyter_notebook_websocket_url(
        server_url="http://localhost:8888",
        token="MY_TOKEN",
        path="test.ipynb"
    )
    async with NbModelClient(ws_url) as notebook:
        cell_index = notebook.add_code_cell("print('hello world')")
        results = notebook.execute_cell(cell_index, kernel)
        print(results)
        assert results["status"] == "ok"
        assert len(results["outputs"]) > 0

Check test.ipynb in JupyterLab. You should see an additional cell with content print('hello world') appended to the notebook, but this time the cell is executed, so the output should show hello world.

You can go further and create a plot with eg matplotlib.

from jupyter_kernel_client import KernelClient
from jupyter_nbmodel_client import NbModelClient, get_jupyter_notebook_websocket_url

CODE = """import matplotlib.pyplot as plt

fig, ax = plt.subplots()

fruits = ['apple', 'blueberry', 'cherry', 'orange']
counts = [40, 100, 30, 55]
bar_labels = ['red', 'blue', '_red', 'orange']
bar_colors = ['tab:red', 'tab:blue', 'tab:red', 'tab:orange']

ax.bar(fruits, counts, label=bar_labels, color=bar_colors)

ax.set_ylabel('fruit supply')
ax.set_title('Fruit supply by kind and color')
ax.legend(title='Fruit color')

plt.show()
"""

with KernelClient(server_url="http://localhost:8888", token="MY_TOKEN") as kernel:
    ws_url = get_jupyter_notebook_websocket_url(
        server_url="http://localhost:8888",
        token="MY_TOKEN",
        path="test.ipynb"
    )
    async with NbModelClient(ws_url) as notebook:
        cell_index = notebook.add_code_cell(CODE)
        results = notebook.execute_cell(cell_index, kernel)
        print(results)
        assert results["status"] == "ok"
        assert len(results["outputs"]) > 0

Check test.ipynb in JupyterLab for the cell with the matplotlib.

[!NOTE]

Instead of using the nbmodel clients as context manager, you can call the start() and stop() methods.

from jupyter_nbmodel_client import NbModelClient, get_jupyter_notebook_websocket_url

kernel = KernelClient(server_url="http://localhost:8888", token="MY_TOKEN")
kernel.start()

try:
    ws_url = get_jupyter_notebook_websocket_url(
        server_url="http://localhost:8888",
        token="MY_TOKEN",
        path="test.ipynb"
    )
    notebook = NbModelClient(ws_url)
    await notebook.start()
    try:
        cell_index = notebook.add_code_cell("print('hello world')")
        results = notebook.execute_cell(cell_index, kernel)
    finally:
        await notebook.stop()
finally:
    kernel.stop()

Usage with Datalayer

To connect to a Datalayer collaborative room, you can use the helper function get_datalayer_notebook_websocket_url:

  • The server is https://prod1.datalayer.run for the Datalayer production SaaS.
  • The room_id is the id of your notebook shown in the URL browser bar.
  • The token is the assigned token for the notebook.

All those details can be retrieved from a Notebook sidebar on the Datalayer SaaS.

from jupyter_nbmodel_client import NbModelClient, get_datalayer_notebook_websocket_url

ws_url = get_datalayer_notebook_websocket_url(
    server_url=server,
    room_id=room_id,
    token=token
)

async with NbModelClient(ws_url) as notebook:
    notebook.add_code_cell("1+1")

Uninstall

To remove the library, run the following.

pip uninstall jupyter_nbmodel_client

Contributing

Development install

# Clone the repo to your local environment
# Change directory to the jupyter_nbmodel_client directory
# Install package in development mode - will automatically enable
# The server extension.
pip install -e ".[test,lint,typing]"

Running Tests

Install dependencies:

pip install -e ".[test]"

To run the python tests, use:

pytest

Development uninstall

pip uninstall jupyter_nbmodel_client

Packaging the library

See RELEASE

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

jupyter_nbmodel_client-0.14.4.tar.gz (25.5 kB view details)

Uploaded Source

Built Distribution

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

jupyter_nbmodel_client-0.14.4-py3-none-any.whl (23.1 kB view details)

Uploaded Python 3

File details

Details for the file jupyter_nbmodel_client-0.14.4.tar.gz.

File metadata

  • Download URL: jupyter_nbmodel_client-0.14.4.tar.gz
  • Upload date:
  • Size: 25.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for jupyter_nbmodel_client-0.14.4.tar.gz
Algorithm Hash digest
SHA256 cb1f2e47a8157e124119801c05381a9323efedca28fa9703367a7df32f9c1889
MD5 3c936149e0cdcddacdf98b6c1a670ec5
BLAKE2b-256 f71e734f19770974bd69c3f6bb7fa04d818d88e17b300a29f6b110484d63e2c4

See more details on using hashes here.

Provenance

The following attestation bundles were made for jupyter_nbmodel_client-0.14.4.tar.gz:

Publisher: release.yml on datalayer/jupyter-nbmodel-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file jupyter_nbmodel_client-0.14.4-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyter_nbmodel_client-0.14.4-py3-none-any.whl
Algorithm Hash digest
SHA256 f1c1583b756602672aa93d1664b3a00ef552b2549a1ef6029f2542929124aa08
MD5 2f29fce9116520e1d9b8784d63038680
BLAKE2b-256 98f78006b0db73a5c0e7c98c2bf003b190f3a9712fc90cfee4cf9e40d73ddd16

See more details on using hashes here.

Provenance

The following attestation bundles were made for jupyter_nbmodel_client-0.14.4-py3-none-any.whl:

Publisher: release.yml on datalayer/jupyter-nbmodel-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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