The Jupyter project started out as IPython and the IPython Notebook. It was originally a Python-specific interactive shell and notebook environment, which later branched out to become language-agnostic, supporting Julia, Python, and R—and potentially anything else.

(© 2021, Ben Nuttall)
IPython is a Python shell—similar to what you get when you type python
or python3
at the command line—but it's more clever and more helpful. If you've ever typed a multi-line command into the Python shell and wanted to repeat it, you'll understand the frustration of having to scroll through your history one line at a time. With IPython, you can scroll back through whole blocks at a time while still being able to navigate line-by-line and edit parts of those blocks.

(© 2021, Ben Nuttall)
It has autocompletion and provides context-aware suggestions:

(© 2021, Ben Nuttall)
It pretty-prints by default:

(Ben Nuttall, CC BY-SA 4.0)
It even allows you to run shell commands:

(Ben Nuttall, CC BY-SA 4.0)
It also provides helpful features like adding ?
to an object as a shortcut for running help()
without breaking your flow:

(Ben Nuttall, CC BY-SA 4.0)
If you're using a virtual environment (see my post on virtualenvwrapper, install it with pip in the environment):
pip install ipython
To install it system-wide, you can use apt on Debian, Ubuntu, or Raspberry Pi:
sudo apt install ipython3
or with pip:
sudo pip3 install ipython
Jupyter notebooks
Jupyter notebooks take the IPython shell to the next level. First of all, they're browser-based, not terminal-based. To get started, install jupyter
.
If you're using a virtual environment, install it with pip in the environment:
pip install jupyter
To install it system-wide, you can use apt on Debian, Ubuntu, or Raspberry Pi:
sudo apt install jupyter-notebook
or with pip:
sudo pip3 install jupyter
Launch the notebook with:
jupyter notebook
This will open in your browser:

(Ben Nuttall, CC BY-SA 4.0)
You can create a new Python 3 notebook using the New dropdown:

(Ben Nuttall, CC BY-SA 4.0)
Now you can write and execute commands in the In[ ]
fields. Use Enter for a newline within the block and Shift+Enter to execute:

(Ben Nuttall, CC BY-SA 4.0)
You can edit and rerun blocks. You can reorder them, delete them, copy/paste, and so on. You can run blocks in any order—but be aware that any variables created will be in scope according to the time of execution, rather than the order they appear within the notebook. You can restart and clear output or restart and run all blocks from within the Kernel menu.
Using the print
function will output every time. But if you only have a single statement that's not assigned or your last statement is unassigned, it will be output anyway:

(Ben Nuttall, CC BY-SA 4.0)
You can even refer to In
and Out
as indexable objects:

(Ben Nuttall, CC BY-SA 4.0)
All the IPython features are available and are often presented a little nicer, too:

(Ben Nuttall, CC BY-SA 4.0)
You can even do inline plots using Matplotlib:

(Ben Nuttall, CC BY-SA 4.0)
Finally, you can save your notebooks and include them in Git repositories, and if you push to GitHub, they will render as completed notebooks—outputs, graphs, and all (as in this example):

(Ben Nuttall, CC BY-SA 4.0)
This article originally appeared on Ben Nuttall's Tooling Tuesday blog and is reused with permission.
Comments are closed.