{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "# Variable Inspector Widget" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## A short example implementation" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "This notebook demonstrates how one can use the widgets already built-in to IPython to create a working variable inspector much like the ones seen in popular commercial scientific computing environments." ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "import ipywidgets as widgets # Loads the Widget framework.\n", "from IPython.core.magics.namespace import NamespaceMagics # Used to query namespace.\n", "\n", "# For this example, hide these names, just to avoid polluting the namespace further\n", "get_ipython().user_ns_hidden['widgets'] = widgets\n", "get_ipython().user_ns_hidden['NamespaceMagics'] = NamespaceMagics" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "class VariableInspectorWindow(object):\n", " instance = None\n", " \n", " def __init__(self, ipython):\n", " \"\"\"Public constructor.\"\"\"\n", " if VariableInspectorWindow.instance is not None:\n", " raise Exception(\"\"\"Only one instance of the Variable Inspector can exist at a \n", " time. Call close() on the active instance before creating a new instance.\n", " If you have lost the handle to the active instance, you can re-obtain it\n", " via `VariableInspectorWindow.instance`.\"\"\")\n", " \n", " VariableInspectorWindow.instance = self\n", " self.closed = False\n", " self.namespace = NamespaceMagics()\n", " self.namespace.shell = ipython.kernel.shell\n", " \n", " self._box = widgets.Box()\n", " self._box._dom_classes = ['inspector']\n", " self._box.background_color = '#fff'\n", " self._box.border_color = '#ccc'\n", " self._box.border_width = 1\n", " self._box.border_radius = 5\n", "\n", " self._modal_body = widgets.VBox()\n", " self._modal_body.overflow_y = 'scroll'\n", "\n", " self._modal_body_label = widgets.HTML(value = 'Not hooked')\n", " self._modal_body.children = [self._modal_body_label]\n", "\n", " self._box.children = [\n", " self._modal_body, \n", " ]\n", " \n", " self._ipython = ipython\n", " self._ipython.events.register('post_run_cell', self._fill)\n", " \n", " def close(self):\n", " \"\"\"Close and remove hooks.\"\"\"\n", " if not self.closed:\n", " self._ipython.events.unregister('post_run_cell', self._fill)\n", " self._box.close()\n", " self.closed = True\n", " VariableInspectorWindow.instance = None\n", "\n", " def _fill(self):\n", " \"\"\"Fill self with variable information.\"\"\"\n", " values = self.namespace.who_ls()\n", " self._modal_body_label.value = '
Name | Type | Value |
---|---|---|
' + \\\n", " ' | ||
'.join(['{0} | {1} | {2}'.format(v, type(eval(v)).__name__, str(eval(v))) for v in values]) + \\\n", " ' |