conda environment file to ini file
# create conda environment
$ mamba env create -f env.yml
# update conda environment
$ mamba env update -n env2ini --file env.yml
# $ mamba env update -n env2ini --file env.mac.yml
pip install -e .
# install from pypi
pip install env2ini
# activate conda environment
$ conda activate env2ini
# make sure the env2ini package is installed in development mode
$ pip install -e .
# make changes under nbs/ directory
# ...
# compile to have changes apply to the ivanova package
$ nbdev_prepare
# publish to pypi
$ nbdev_pypi
# publish to conda
$ nbdev_conda
Install latest from the GitHub repository:
$ pip install git+https://github.com/dsm-72/env2ini.git
or from conda
$ conda install -c dsm-72 env2ini
or from pypi
$ pip install env2ini
Documentation can be found hosted on GitHub repository pages. Additionally you can find package manager specific guidelines on conda and pypi respectively.
$ env2ini --help
| Option | Short Option | Type | Description | Default Value |
|------------------------|--------------|------|------------------------------------------------------------------------------------------------|----------------|
| --file
| -f
| TEXT | YAML file to extract the new requirements from. | env.yml
|
| --ini-file
| -i
| TEXT | The settings.ini
file to update. | settings.ini
|
| --mps
| -m
| | Whether or not to use the mps env file ({os.path.basename(file)}.mps.yml
). | |
| --dryrun
| -d
| | Whether to actually update the settings.ini
file or just print the changes. | |
| --unchanged
| -u
, -a
| | Whether to print all packages, including the ones whose versions haven’t changed. | |
| --ignore
| -ig
| TEXT | List of dependencies to ignore. | None
|
| --alias
| -al
| TEXT | Dictionary of aliases for conda dependencies in the format: package1:alias1;package2:alias2
. | None
|
| --confirm
| -c
| | Ask for confirmation before writing to the ini
file. | True
|
| --install-completion
| | | Install completion for the current shell. | |
| --show-completion
| | | Show completion for the current shell, to copy it or customize the installation. | |
| --help
| | | Show this message and exit. | |
You can also update the conda environment file to modify the behavior
under a key env2ini
:
dependencies:
# for conda plugins
- conda
# for publishing to pypi and conda
- twine
- anaconda-client
# env2ini specifications
env2ini:
# packages to ignore (not moved to settings.ini)
ignore:
- pip
- python
- twine
- anaconda-client
- notebook
- ipykernel
- ipywidgets
- jupyter_contrib_nbextensions
# mapping of the name of the package on conda to that of its name in pypi
aliases:
torch: pytorch
lightning: pytorch-lightning
Note: doing so will yield a warning which looks like this:
EnvironmentSectionNotValid: The following section on 'path/to/file/env.yml' is invalid and will be ignored:
- env2ini
Here is the full environment file can be found under env.mps.yml
with
which this package was made:
name: env2ini
channels:
- conda-forge
- fastai
dependencies:
- python>=3.10
# Utilities
# -------------------------------------------------------------------------
- tqdm
- rich
- typer
# Jupyter Notebook
# -------------------------------------------------------------------------
- conda-forge::notebook
- conda-forge::ipykernel
- conda-forge::ipywidgets
- conda-forge::jupyter_contrib_nbextensions
# nbdev
# -------------------------------------------------------------------------
- fastai::nbdev>=2.3.12
- pyyaml
# for conda plugins
- conda
# for publishing to pypi and conda
- twine
- anaconda-client
env2ini:
ignore:
- pip
- python
- twine
- anaconda-client
- notebook
- ipykernel
- ipywidgets
- jupyter_contrib_nbextensions
aliases:
torch: pytorch
lightning: pytorch-lightning
the deprecated original script env_to_ini.py
This script is not a part of the package. It is however provided to show
where the project came from. It was designed so that if your env.yml
(or env.mac.yml
) file changes you can automatically update the
depedencies of the env2ini
package (under settings.ini
) to match.
$ python env_to_ini.py
# show packages that didnt change
$ python env_to_ini.py --unchanged