Working in the Notebook¶
Inline Plots¶
To display Bokeh plots inline in an Jupyter notebook, use the
output_notebook()
function from bokeh.io instead of (or in addition to)
the output_file()
function we have seen previously. No other modifications
are required. When show()
is called, the plot will be displayed inline in
the next notebook output cell. You can see a screenshot below:
data:image/s3,"s3://crabby-images/29f36/29f36d5d5aa96a2fee045d4a9062bf7976b269cd" alt="../../_images/notebook_inline.png"
Note
As a convenience, output_notebook()
is also importable from the
bokeh.charts and bokeh.plotting modules.
Notebook Handles¶
It is possible to update a previously shown plot in-place. When the argument
notebook_handle=True
is passed to show()
then a handle object is returned.
This handle object can be used with the push_notebook()
function to update
the plot with any recent changes to plots properties, data source values, etc.
The following screenshots walk through the basic usage of notebook handles.
- First, import standard functions, as well as
push_notebook()
:
data:image/s3,"s3://crabby-images/de1d6/de1d63d15b7c46741af0aa7c62997ddb3283418f" alt="../../_images/notebook_comms1.png"
- Next, create some plots, and make sure to pass
notebook_handle=True
toshow()
:
data:image/s3,"s3://crabby-images/66afc/66afc228205744b46116759370f3bda1432ea7dc" alt="../../_images/notebook_comms2.png"
- Looking at the handle, see that it is associated with the output cell
for
In[2]
that was just displayed:
data:image/s3,"s3://crabby-images/9759b/9759b9c6273d3ed23794c1c039d06844cbf8497e" alt="../../_images/notebook_comms3.png"
- Now, update any properties of the plot, then call
push_notebook()
with the handle:
data:image/s3,"s3://crabby-images/8c6e3/8c6e343eb84f03dae63a614ae8c0be7b8d2f57f3" alt="../../_images/notebook_comms4.png"
- After doing so, note that the earlier output cell for
In[2]
has changed (without being re-executed)
data:image/s3,"s3://crabby-images/cf070/cf070ecb7aa01f077d1c34f3095f25805f1e7321" alt="../../_images/notebook_comms5.png"
More detailed demonstrations of using notebook handles can be found in the following example notebooks:
Jupyter Interactors¶
It is possible to drive updates to Bokeh plots using Jupyter notebook widgets,
known as interactors. The key doing this is the push_notebook()
function
described above. Typically it is called in the update callback for the
interactors, to update the plot from widget values. A screenshot of the
examples/howto/notebook_comms/Jupyter Interactors.ipynb example
notebook is shown below:
data:image/s3,"s3://crabby-images/bb906/bb90660c824d41da7cecb0c3e8aa70a1ed040e6c" alt="../../_images/notebook_interactors.png"