5 Best Ways to Install Python SciPy

Rate this post

πŸ’‘ Problem Formulation: You want to install the SciPy library, a cornerstone of scientific computing with Python, to leverage its powerful modules for optimization, linear algebra, integration, and more. Whether you’re looking to crunch numbers for a data analysis project or simulate physical phenomena, you need SciPy efficiently installed in your Python environment. Below are five tried-and-true methods to get you up and running with SciPy, covering various scenarios and preferences.

Method 1: Installing SciPy with pip

Pip is Python’s default package installer and is often the most straightforward tool for installing packages like SciPy. This method is best for users who have a simple Python setup and are comfortable with command line tools. It involves using pip to download and install SciPy from the Python Package Index (PyPI).

Here’s an example:

pip install scipy


Collecting scipy
  Downloading scipy-1.7.1-cp38-cp38-win_amd64.whl (33.6 MB)
     |β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆ| 33.6 MB 1.5 MB/s
Successfully installed scipy-1.7.1

This code snippet uses pip to fetch the latest version of SciPy from PyPI and installs it into your Python environment. It’s a quick one-step process.

Method 2: Installing SciPy using Anaconda

For users who manage their packages with Anaconda, installing SciPy can be effortless. Anaconda simplifies package management and deployment for scientific computing and comes with SciPy pre-installed in its base environment. However, you can also install it in a separate environment if needed.

Here’s an example:

conda install scipy


# All requested packages already installed.

In this code snippet, the conda install command is used to add SciPy to your current conda environment. If it’s already installed, conda will simply report that all requested packages are installed.

Method 3: Installing SciPy using a virtual environment

If you’re working on multiple Python projects with differing dependencies, it might be a good idea to use virtual environments. Virtual environments allow you to manage dependencies for different projects separately by creating isolated Python environments. Installing SciPy within a virtual environment ensures no conflicts with other projects.

Here’s an example:

python -m venv my_env
source my_env/bin/activate
pip install scipy


Successfully installed scipy-1.7.1

This code snippet first creates a new virtual environment named ‘my_env’ and then activates it. Once the virtual environment is active, SciPy is installed using pip as before, but confined to ‘my_env’ only.

Method 4: Install SciPy from source

Advanced users may prefer to install SciPy from source. This allows for customization and optimization specific to your system’s architecture. It’s also the method to go for if you need the cutting-edge version directly from the SciPy repository. Ensure you have a C compiler and the necessary tools and libraries before attempting this.

Here’s an example:

git clone https://github.com/scipy/scipy.git
cd scipy
python setup.py install


Running from SciPy source directory.
Finished processing dependencies for scipy

This snippet demonstrates how to clone the SciPy repository from GitHub, navigate into the cloned directory, and install it using Python’s setup script. This method requires more knowledge and setup but offers greater control over the installation.

Bonus One-Liner Method 5: Using pip with requirements.txt

In collaborative projects, it is common to share a requirements.txt file that lists all the necessary packages. You can include SciPy in this file and install all dependencies with a single pip command, which is neat for rapid setup and consistent environments across teams.

Here’s an example:

echo scipy==1.7.1 > requirements.txt
pip install -r requirements.txt


Collecting scipy==1.7.1
  Using cached scipy-1.7.1-cp38-cp38-win_amd64.whl (33.6 MB)
Installing collected packages: scipy
Successfully installed scipy-1.7.1

This snippet creates a requirements.txt file with SciPy and its preferred version, then uses pip to install SciPy from this file, ensuring version control and easy installation for other users.


  • Method 1: Installing with pip. Straightforward, universally applicable. May not resolve complex dependency issues.
  • Method 2: Using Anaconda. Simplifies complex installations. May be overkill for simple projects or environments.
  • Method 3: Virtual environment setup. Ideal for managing multiple projects. Requires familiarity with Python environments.
  • Method 4: Install from source. Provides the most control. Needs a C compiler and may require complex troubleshooting.
  • Method 5: Requirements.txt. Great for teams and consistent environments. Requires diligence in maintaining the requirements file.