The shell is the technical name for the command line. While all of our Python work in this course has been via Jupyter Notebooks, historically most programming has involved using the shell.
Zsh and Bash are quite similar in basic use; Zsh is a successor to Bash, and it's more powerful as you take on more complex tasks. Powershell has almost nothing in common with the other two.
Fortunately, in Windows installations, Anaconda comes with its own shell: Anaconda Prompt. If you use Windows, I recommend using this instead of Powershell to interact with Python and the related tools.
Shells typically only accept text input and show text output. The mouse doesn't register, and there are no images.
This type of environment can be very intimidating to newcomers -- and sometimes even to intermediate users -- but the shell is important.
The shell is alternatively sometimes called the command line or the terminal. These terms have subtly different meanings, but for most discussions you can treat them as interchangeable.
Reasons to use the shell:
Most shell prompts look something like this:
Or like this
Or, on CSI, like this:
The text up to and including the dollar sign is called the prompt.
It's a prompt because it's prompting the user to enter input. You, the user, enter commands after that trailing $
, %
, or >
(depending on which shell you use -- here $
for Bash) -- and the shell shows results in the space below.
Above, I ran the ls
command, short for list files. The shell printed a list of files in my home directory.
Then it printed a new prompt. Ready for more commands!
On whatever platform you're using, you can access a terminal shell through VS Code.
In the "Terminal" menu, one of the options is "New Terminal":
However, in my experience, this shell isn't the best option on Windows. Instead, I recommend Anaconda Prompt, which should be a program available in the Start menu.
Open a shell -- on Mac, through VS Code; on Windows, by launching Anaconda Prompt.
Type conda
and see what happens.
On Mac, type ls
and run it; on Windows, dir
.
Can you figure out what information these commands are outputting?
Unfortunately, we don't have time in this course to cover general shell usage.
But we will talk about how to run Python from the shell....
Before Jupyter notebooks, the way to work interactively was through the Python REPL.
REPL stands for Read, Evaluate, Print, Loop.
Python reads input (code) from the user, evaluates that input (runs the code), prints any results, and then loops back to the beginning and starts again.
When you think about it, this is pretty much what Jupyter notebooks do: read the code you type in a cell, evaluate it, print output, and start a new cell where you can do it again.
There are a two versions of the Python REPL:
?
.We're going to use IPython. In my own work, I use IPython often -- sometimes even when Jupyter Notebooks are available.
Open the shell on your device and type ipython
(case matters!).
Take a look at the prompt that appears, and then type x = 4
.
Now print(x)
.
Hopefully you saw that IPython is just like Python in notebooks (except it doesn't support markdown and graphics).
If you don't do much plotting, this interface can be a perfectly good way of working in Python.
I like it because it's more compact than Jupyter notebooks –- I can work quickly in IPython and keep other windows open as well. Often I write experimental code in IPython and copy the parts I want to keep to another file.
Speaking of other files, what type of file would one copy Python code to?
A file with a .py extension, the native extension for a Python script.
Question: What is the file extension for Jupyter notebooks? Why is this different from .py?
.py files are plain text; there's nothing in them but Python code.
This is in contrast to notebooks, which save a lot of metadata:
A .py file is sometimes called a Python script, a term for a file containing source code.
Other languages, like R, Perl, and Ruby, also call their source code files "scripts".
Though .py files do come with fewer features than notebooks, they are excellent at a few things:
You can write a .py file in any text editor that's capable of saving plain text, or files that contain text and nothing else.
Most text editors for creating complex, styled documents are not suited for this purpose, e.g. Microsoft Word, Google Docs, or Apple Pages.
However, VS Code can handle Python files natively -- simply open a new file and switch the language to Python by clicking this text at the bottom:
It will open a new dialogue where you can select Python:
Rename the file (by right-clicking on the current filename, untitled.txt
) to script.py
.
The important thing is that it ends in .py
.
Then go to File > Save. Close the window when you're finished.
.py files are run with the syntax
python <myfile.py>
where <myfile.py>
is replaced with the name of the .py file (no chevrons).
However, your terminal session must be in the same folder as the Python file -- Python only looks for files in the current directory.
A discussion of directory navigation from the command line is beyond the scope of this class, but if you expect to work from the shell often, it's a topic worth researching.
Take a moment to open a terminal and run your new .py file in the shell with
python script.py
What output is produced?
While the preferred way of creating .py files is via a plain-text editor, it's possible to convert a Jupyter notebook to a .py file.
In VS Code you can use the command palette for this purpose. To open the command palette, type control-shift-P (on Windows) or command-shift-P (on Mac) and begin typing the word "export". You should see the option to export to a Python script:
However, this translation isn't perfect: markdown cells will become regular comments, and cell magics (which we will discuss shortly) will break when run in regular Python.
Previously, we talked about how Python is the same in the shell as it is in Jupyter; however, this is a slight simplification.
Let's dive into precisely when and how Python behaves differently in the two contexts.
The most obvious difference between the shell and notebooks is that the latter supports graphics -- styled text rendering (markdown cells) and plots/visuals.
If you want to produce graphics from the shell, it is possible although we don't recommend it.
Different plotting libraries have different settings to enable graphics from the shell, and those visuals will usually appear in a pop-up window.
In Jupyter, you've seen that variables/expressions on the last line of a cell are printed out. E.g.
y = 10
y
10
In the Python REPL, this rule still applies. But not so in .py files! (They don't have any cells.)
In Python scripts, only explicit print
calls will yield any output.
So as a script-writer, you need to be more mindful of what output you would like to have displayed.
y = 10
print(y)
10
?
¶We haven't discussed cell magics, but you may see examples of them in others' code.
Cell magics begin with one or two percent signs.
For example, you can time the execution of a cell by putting %%time
at the beginning.
Cell magics, along with the ?
for accessing help documentation, are Jupyter-specific features.
Some work in the IPython REPL (though not in the classic Python REPL), but none work in .py files.
As we've discussed above, only .py files can be batched -- the .ipynb format of notebooks is strictly an interactive format.
However, it's worth noting that there are projects working toward making .ipynb files batch-able. The most prominent example of this is Papermill, an open-source tool developed by Netflix (who relies heavily on Jupyter Notebooks in their data science department).
Are there any questions before moving on?