Software install instructions

[this page is adapted from https://aaltoscicomp.github.io/python-for-scicomp/installation/]

Choosing an installation method

For this course we will install an isolated environment with following dependencies:

name: course
channels:
  - conda-forge
dependencies:
  - python <= 3.12
  - jupyterlab
  - altair-all
  - vega_datasets
  - pandas
  - numpy
  - pytest
  - scalene
  - ruff
  - icecream
  - myst-parser
  - sphinx
  - sphinx-rtd-theme
  - sphinx-autoapi
  - sphinx-autobuild

If you are used to installing packages in Python and know what to do with the above files, please follow your own preferred installation method.

If you are new to Python or unsure how to create isolated environments in Python from files above, please follow the instructions below.

There are many choices and we try to suggest a good compromise

There are very many ways to install Python and packages with pros and cons and in addition there are several operating systems with their own quirks. This can be a huge challenge for beginners to navigate. It can also difficult for instructors to give recommendations for something which will work everywhere and which everybody will like.

Below we will recommend Miniforge since it is free, open source, general, available on all operating systems, and provides a good basis for reproducible environments. However, it does not provide a graphical user interface during installation. This means that every time we want to start a JupyterLab session, we will have to go through the command line.

Installing Python via Miniforge

Follow the instructions on the miniforge web page. This installs the base, and from here other packages can be installed.

Unsure what to download and what to do with it?

You want to download and run Miniforge3-Windows-x86_64.exe.

Installing and activating the software environment

First we will start Python in a way that activates conda/mamba. Then we will install the software environment from this environment.yml file.

An environment is a self-contained set of extra libraries - different projects can use different environments to not interfere with each other. This environment will have all of the software needed for this particular course.

We will call the environment course.

Use the “Miniforge Prompt” to start Miniforge. This will set up everything so that conda and mamba are available. Then type (without the $):

$ mamba env create -n course -f https://raw.githubusercontent.com/coderefinery/python-progression/main/software/environment.yml

Starting JupyterLab

Every time we want to start a JupyterLab session, we will have to go through the command line and first activate the course environment.

Start the Miniforge Prompt. Then type (without the $):

$ conda activate course
$ jupyter-lab

Removing the software environment

In the Miniforge Prompt, type (without the $):

$ conda env list
$ conda env remove --name course
$ conda env list

How to verify your installation

Start JupyterLab (as described above). It will hopefully open up your browser and look like this:

JupyterLab opened in the browser

JupyterLab opened in the browser. Click on the Python 3 tile.

Once you clicked the Python 3 tile it should look like this:

Python 3 notebook started

Python 3 notebook started.

Into that blue “cell” please type the following:

import altair
import pandas

print("all good - ready for the course")
Screenshot where we test to import required libraries.

Please copy these lines and click on the “play”/”run” icon.

This is how it should look:

Screenshot after successful import.

Screenshot after successful import.

If this worked, you are all set and can close JupyterLab (no need to save these changes).

This is how it should not look:

Required packages could not be found.

Error: required packages could not be found.