================= Managing packages ================= .. note:: There are many options available for the commands described on this page. For details, see :doc:`commands <../../commands/index>`. Searching for packages ====================== Use the terminal for the following steps. To see if a specific package, such as SciPy, is available for installation: .. code-block:: bash conda search scipy To see if a specific package, such as SciPy, is available for installation from Anaconda.org: .. code-block:: bash conda search --override-channels --channel defaults scipy To see if a specific package, such as iminuit, exists in a specific channel, such as http://conda.anaconda.org/mutirri, and is available for installation: .. code-block:: bash conda search --override-channels --channel http://conda.anaconda.org/mutirri iminuit Installing packages =================== Use the terminal for the following steps. To install a specific package such as SciPy into an existing environment "myenv": .. code-block:: bash conda install --name myenv scipy If you do not specify the environment name, which in this example is done by ``--name myenv``, the package installs into the current environment: .. code-block:: bash conda install scipy To install a specific version of a package such as SciPy: .. code-block:: bash conda install scipy=0.15.0 .. _`installing multiple packages`: To install multiple packages at once, such as SciPy and cURL: .. code-block:: bash conda install scipy curl .. note:: It is best to install all packages at once, so that all of the dependencies are installed at the same time. To install multiple packages at once and specify the version of the package: .. code-block:: bash conda install scipy=0.15.0 curl=7.26.0 To install a package for a specific Python version: .. code-block:: bash conda install scipy=0.15.0 curl=7.26.0 -n py34_env If you want to use a specific Python version, it is best to use an environment with that version. For more information, see :doc:`../troubleshooting`. Installing similar packages =========================== Installing packages that have similar filenames and serve similar purposes may return unexpected results. The package last installed will likely determine the outcome, which may be undesirable. If the two packages have different names, or if you're building variants of packages and need to line up other software in the stack, we recommend using :ref:`mutex-metapackages`. Installing packages from Anaconda.org ===================================== Packages that are not available using ``conda install`` can be obtained from Anaconda.org, a package management service for both public and private package repositories. Anaconda.org is an Anaconda product, just like Anaconda and Miniconda. To install a package from Anaconda.org: #. In a browser, go to http://anaconda.org. #. To find the package named bottleneck, type ``bottleneck`` in the top-left box named Search Packages. #. Find the package that you want and click it to go to the detail page. The detail page displays the name of the channel. In this example it is the "pandas" channel. #. Now that you know the channel name, use the ``conda install`` command to install the package. In your terminal window, run: .. code:: conda install -c pandas bottleneck This command tells conda to install the bottleneck package from the pandas channel on Anaconda.org. #. To check that the package is installed, in your terminal window, run: .. code:: conda list A list of packages appears, including bottleneck. .. note:: For information on installing packages from multiple channels, see :doc:`manage-channels`. Installing non-conda packages ============================= If a package is not available from conda or Anaconda.org, you may be able to find and install the package via conda-forge or with another package manager like pip. Pip packages do not have all the features of conda packages and we recommend first trying to install any package with conda. If the package is unavailable through conda, try finding and installing it with `conda-forge `_. If you still cannot install the package, you can try installing it with pip. The differences between pip and conda packages cause certain unavoidable limits in compatibility but conda works hard to be as compatible with pip as possible. .. note:: Both pip and conda are included in Anaconda and Miniconda, so you do not need to install them separately. Conda environments replace virtualenv, so there is no need to activate a virtualenv before using pip. It is possible to have pip installed outside a conda environment or inside a conda environment. To gain the benefits of conda integration, be sure to install pip inside the currently active conda environment and then install packages with that instance of pip. The command ``conda list`` shows packages installed this way, with a label showing that they were installed with pip. You can install pip in the current conda environment with the command ``conda install pip``, as discussed in :ref:`pip-in-env`. If there are instances of pip installed both inside and outside the current conda environment, the instance of pip installed inside the current conda environment is used. To install a non-conda package: #. Activate the environment where you want to put the program: * In your terminal window, run ``conda activate myenv``. #. To use pip to install a program such as See, in your terminal window, run:: pip install see #. To verify the package was installed, in your terminal window, run: .. code:: conda list If the package is not shown, install pip as described in :ref:`pip-in-env` and try these commands again. Installing commercial packages ============================== Installing a commercial package such as IOPro is the same as installing any other package. In your terminal window, run: .. code-block:: bash conda install --name myenv iopro This command installs a free trial of one of Anaconda's commercial packages called `IOPro `_, which can speed up your Python processing. Except for academic use, this free trial expires after 30 days. Viewing a list of installed packages ==================================== Use the terminal for the following steps. To list all of the packages in the active environment: .. code:: conda list To list all of the packages in a deactivated environment: .. code:: conda list -n myenv Listing package dependencies ============================ To find what packages are depending on a specific package in your environment, there is not one specific conda command. It requires a series of steps: #. List the dependencies that a specific package requires to run: ``conda search package_name --info`` #. Find your installation’s package cache directory: ``conda info`` #. Find package dependencies. By default, Anaconda/Miniconda stores packages in ~/anaconda/pkgs/ (or ~/opt/pkgs/ on macOS Catalina). Each package has an index.json file which lists the package’s dependencies. This file resides in ~anaconda/pkgs/package_name/info/index.json. #. Now you can find what packages depend on a specific package. Use grep to search all index.json files as follows: ``grep package_name ~/anaconda/pkgs/*/info/index.json`` The result will be the full package path and version of anything containing the . Example: ``grep numpy ~/anaconda3/pkgs/*/info/index.json`` Output from the above command:: /Users/testuser/anaconda3/pkgs/anaconda-4.3.0-np111py36_0/info/index.json: numpy 1.11.3 py36_0 /Users/testuser/anaconda3/pkgs/anaconda-4.3.0-np111py36_0/info/index.json: numpydoc 0.6.0 py36_0 /Users/testuser/anaconda3/pkgs/anaconda-4.3.0-np111py36_0/info/index.json: numpy 1.11.3 py36_0 Note this also returned “numpydoc” as it contains the string “numpy”. To get a more specific result set you can add \< and \>. Updating packages ================= Use ``conda update`` command to check to see if a new update is available. If conda tells you an update is available, you can then choose whether or not to install it. Use the terminal for the following steps. * To update a specific package: .. code:: conda update biopython * To update Python: .. code:: conda update python * To update conda itself: .. code:: conda update conda .. note:: Conda updates to the highest version in its series, so Python 3.8 updates to the highest available in the 3.x series. To update the Anaconda metapackage: .. code-block:: bash conda update conda conda update anaconda Regardless of what package you are updating, conda compares versions and then reports what is available to install. If no updates are available, conda reports "All requested packages are already installed." If a newer version of your package is available and you wish to update it, type ``y`` to update: .. code:: Proceed ([y]/n)? y .. _pinning-packages: Preventing packages from updating (pinning) =========================================== Pinning a package specification in an environment prevents packages listed in the ``pinned`` file from being updated. In the environment's ``conda-meta`` directory, add a file named ``pinned`` that includes a list of the packages that you do not want updated. EXAMPLE: The file below forces NumPy to stay on the 1.7 series, which is any version that starts with 1.7. This also forces SciPy to stay at exactly version 0.14.2:: numpy 1.7.* scipy ==0.14.2 With this ``pinned`` file, ``conda update numpy`` keeps NumPy at 1.7.1, and ``conda install scipy=0.15.0`` causes an error. Use the ``--no-pin`` flag to override the update restriction on a package. In the terminal, run: .. code-block:: bash conda update numpy --no-pin Because the ``pinned`` specs are included with each conda install, subsequent ``conda update`` commands without ``--no-pin`` will revert NumPy back to the 1.7 series. Adding default packages to new environments automatically ========================================================= To automatically add default packages to each new environment that you create: #. Open a terminal window and run: ``conda config --add create_default_packages PACKAGENAME1 PACKAGENAME2`` #. Now, you can create new environments and the default packages will be installed in all of them. You can also :ref:`edit the .condarc file ` with a list of packages to create by default. You can override this option at the command prompt with the ``--no-default-packages`` flag. Removing packages ================= Use the terminal for the following steps. * To remove a package such as SciPy in an environment such as myenv: .. code-block:: bash conda remove -n myenv scipy * To remove a package such as SciPy in the current environment: .. code-block:: bash conda remove scipy * To remove multiple packages at once, such as SciPy and cURL: .. code-block:: bash conda remove scipy curl * To confirm that a package has been removed: .. code:: conda list