Python: различия между версиями

Материал из wiki.nntc.nnov.ru
Перейти к навигации Перейти к поиску
(Активация venv)
(Виртуальное окружение (venv))
Строка 17: Строка 17:
 
  (envname) $
 
  (envname) $
  
==Версии python==
+
==Справка по модулю==
 +
$ python3 -m venv --help
 +
usage: venv [-h] [--system-site-packages] [--symlinks | --copies] [--clear]
 +
            [--upgrade] [--without-pip] [--prompt PROMPT] [--upgrade-deps]
 +
            ENV_DIR [ENV_DIR ...]
 +
Creates virtual Python environments in one or more target directories.
 +
 +
positional arguments:
 +
  ENV_DIR              A directory to create the environment in.
 +
 +
options:
 +
  -h, --help            show this help message and exit
 +
  --system-site-packages
 +
                        Give the virtual environment access to the system
 +
                        site-packages dir.
 +
  --symlinks            Try to use symlinks rather than copies, when symlinks
 +
                        are not the default for the platform.
 +
  --copies              Try to use copies rather than symlinks, even when
 +
                        symlinks are the default for the platform.
 +
  --clear              Delete the contents of the environment directory if it
 +
                        already exists, before environment creation.
 +
  --upgrade            Upgrade the environment directory to use this version
 +
                        of Python, assuming Python has been upgraded in-place.
 +
  --without-pip        Skips installing or upgrading pip in the virtual
 +
                        environment (pip is bootstrapped by default)
 +
  --prompt PROMPT      Provides an alternative prompt prefix for this
 +
                        environment.
 +
  --upgrade-deps        Upgrade core dependencies: pip setuptools to the
 +
                        latest version in PyPI
 +
 +
Once an environment has been created, you may wish to activate it, e.g. by sourcing an activate script in its bin directory.
 +
 
 +
==Способы создания venv==
 
===Создание виртуального окружения с символическими ссылками на интерпретатор Python===
 
===Создание виртуального окружения с символическими ссылками на интерпретатор Python===
 
По умолчанию виртуальные окружения создаются с использованием стандартного системного Python. Файл bin/python — это просто символическая ссылка на системный python:
 
По умолчанию виртуальные окружения создаются с использованием стандартного системного Python. Файл bin/python — это просто символическая ссылка на системный python:

Версия 00:12, 23 февраля 2023

Установка

Установка интерпретатора Python 3

apt-get install python3

Установка модуля venv

Python 3.3+ поставляется с модулем venv.

Виртуальное окружение (venv)

Виртуальное окружение (virtual environment) — это каталог, в который устанавливаются некоторые исполняемые файлы и скрипты. Среди файлов есть python для выполнения скриптов и pip для установки других модулей в окружении. Также есть скрипты для активации окружения в различных командных облочках (по одному для bash, csh и fish). По сути, виртуальное окружение имитирует полную системную установку Python и всех необходимых модулей, не вмешиваясь в работу системы, на которой будет запускаться приложение.

Создание нового venv

python3 -m venv /path/to/new/virtual/environment

Активация venv

Для активации виртуального окружения используйте один из имеющихся скриптов для вашей командной оболочки. Пример для bash:

$ source envname/bin/activate
(envname) $

Справка по модулю

$ python3 -m venv --help
usage: venv [-h] [--system-site-packages] [--symlinks | --copies] [--clear]
            [--upgrade] [--without-pip] [--prompt PROMPT] [--upgrade-deps]
            ENV_DIR [ENV_DIR ...]
Creates virtual Python environments in one or more target directories.

positional arguments:
  ENV_DIR               A directory to create the environment in.

options:
  -h, --help            show this help message and exit
  --system-site-packages
                       Give the virtual environment access to the system
                       site-packages dir.
 --symlinks            Try to use symlinks rather than copies, when symlinks
                       are not the default for the platform.
 --copies              Try to use copies rather than symlinks, even when
                       symlinks are the default for the platform.
 --clear               Delete the contents of the environment directory if it
                       already exists, before environment creation.
 --upgrade             Upgrade the environment directory to use this version
                       of Python, assuming Python has been upgraded in-place.
 --without-pip         Skips installing or upgrading pip in the virtual
                       environment (pip is bootstrapped by default)
 --prompt PROMPT       Provides an alternative prompt prefix for this
                       environment.
 --upgrade-deps        Upgrade core dependencies: pip setuptools to the
                       latest version in PyPI

Once an environment has been created, you may wish to activate it, e.g. by sourcing an activate script in its bin directory.

Способы создания venv

Создание виртуального окружения с символическими ссылками на интерпретатор Python

По умолчанию виртуальные окружения создаются с использованием стандартного системного Python. Файл bin/python — это просто символическая ссылка на системный python:

$ ls -l envname/bin/python
lrwxrwxrwx 1 foo foo 15 янв 29 18:48 envname/bin/python -> /usr/bin/python

Создание виртуального окружения с копией интерпретатора Python

$ python3 -m venv envname --copies 
$ ls envname/bin/python -l
-rwxr-xr-x 1 vladt vladt 5872328 фев 23 00:00 envname/bin/python