(This is simplified documentation from https://jupyter-notebook.readthedocs.io. You are more than welcome to visit the aforementioned page for more details)

Jupyter Notebooks#

Introduction#

The Jupyter Notebook is an interactive computing environment that enables users to author notebook documents that include:

  • Live code

  • Interactive widgets

  • Plots

  • Narrative text

  • Equations

  • Images

  • Video

Components#

The Jupyter Notebook combines three components:

  • The notebook web application: An interactive web application for writing and running code interactively and authoring notebook documents.

  • Kernels: Separate processes started by the notebook web application that runs users’ code in a given language and returns output back to the notebook web application. The kernel also handles things like computations for interactive widgets, tab completion and introspection.

  • Notebook documents: Self-contained documents that contain a representation of all content visible in the notebook web application, including inputs and outputs of the computations, narrative text, equations, images, and rich media representations of objects. Each notebook document has its own kernel.

Notebook documents#

When you run the notebook web application on your computer, notebook documents are just files on your local filesystem with a .ipynb extension. This allows you to use familiar workflows for organizing your notebooks into folders and sharing them with others.

Notebooks consist of a linear sequence of cells. There are three basic cell types:

  • Code cells: Input and output of live code that is run in the kernel

# This a code cell. Code rom https://seaborn.pydata.org/examples/grouped_boxplot.html
import seaborn as sns
sns.set_theme(style="ticks", palette="pastel")

# Load the example tips dataset
tips = sns.load_dataset("tips")

# Draw a nested boxplot to show bills by day and time
sns.boxplot(x="day", y="total_bill",
            hue="smoker", palette=["m", "g"],
            data=tips)
sns.despine(offset=10, trim=True)
../../_images/210b9aff75364a45f8a928353bcc36d29a0dd9e9f866edd9b0dbffa835c4d56f.png
  • Markdown cells: arrative text with embedded LaTeX equations

This is here is mardown. As such Markdown rules apply here!

  • Raw cells: Unformatted text that is included, without modification, when notebooks are converted to different formats using nbconvert

Notebook Basics#

Mouse navigation#

All navigation and actions in the Notebook are available using the mouse through the menubar and toolbar, which are both above the main Notebook area.

A couple of basic ideas:

  • cells can be selected by clicking on them. The currently selected cell gets a grey or green border depending on whether the notebook is in edit or command mode. If you click inside a cell’s editor area, you will enter edit mode. If you click on the prompt or output area of a cell you will enter command mode.

  • cell actions usually apply to the currently selected cell. Thus if you want to run the code in a cell, you would select it and click the button in the toolbar or the “Cell:Run” menu item. Similarly, to copy a cell you would select it and click the button in the toolbar or the “Edit:Copy” menu item. With this simple pattern, you should be able to do most everything you need with the mouse.

Keyboard Navigation#

The modal user interface of the Jupyter Notebook has been optimized for efficient keyboard usage. This is made possible by having two different sets of keyboard shortcuts: one set that is active in edit mode and another in command mode.

The most important keyboard shortcuts are Enter, which enters edit mode, and Esc, which enters command mode.

In edit mode, most of the keyboard is dedicated to typing into the cell’s editor. Thus, in edit mode there are relatively few shortcuts. In command mode, the entire keyboard is available for shortcuts, so there are many more. The Help->Keyboard Shortcuts dialog lists the available shortcuts.

I recommend learning the command mode shortcuts - you will need to be sure having pressed Esc for this - in the following rough order:

  1. Basic navigation: enter, shift-enter, up/k, down/j

  2. Saving the notebook: s

  3. Change Cell types: y, m, 1-6, t

  4. Cell creation: a, b

  5. Cell editing: x, c, v, d, z

Running Code (edit mode)#

  • Shift-Enter or pressing the button in the toolbar above runs a code cell.

  • Alt-Enter runs the current cell and inserts a new one below.

  • Ctrl-Enter run the current cell and enters command mode.

Cell menu#

The “Cell” menu has a number of menu items for running code in different ways. These includes:

  • Run and Select Below

  • Run and Insert Below

  • Run All

  • Run All Above

  • Run All Below

Restarting the kernels#

The kernel maintains the state of a notebook’s computations. You can reset this state by restarting the kernel. This is done by clicking on the in the toolbar above.

Exercise 1

Create a cell below or above using either the keyworad with one of the shortcuts shown before, or using the menu with the mouse. Then, change to edit mode in the created cell and try introducing a number and running the cell using any of the above combinations. Do the same now, but changing the cell to markdown and typing some text in it.

More Resources#