MyTetra Share
Делитесь знаниями!
Время создания: 24.10.2021 17:12
Автор: alensav
Текстовые метки: python jgsn ghbtvs
Раздел: PYTHON
Запись: alensav/MyTetra2/main/base/1635084778zp5bafx83x/text.html на raw.githubusercontent.com

Приемы_PYTHON

1. Редактор - idle3

2. -'- geany

3. #!/usr/bin/python3

# -*- coding: UTF-8 -*-

======================================================================================

12. Виртуальные среды и пакеты

12.1. Введение

Приложения Python часто используют пакеты и модули, которые не входят в стандартную библиотеку. Иногда приложениям требуется определенная версия библиотеки, потому что приложение может требовать, чтобы конкретная ошибка была исправлена, или приложение может быть написано с использованием устаревшей версии интерфейса библиотеки.

Это означает, что одна установка Python может не соответствовать требованиям каждого приложения. Если приложению A требуется версия 1.0 определенного модуля, а приложению B - версия 2.0, тогда требования противоречат друг другу, и при установке версии 1.0 или 2.0 одно приложение не сможет работать.

Решением этой проблемы является создание виртуальной среды , автономного дерева каталогов, содержащего установку Python для конкретной версии Python, а также ряд дополнительных пакетов.

Тогда разные приложения могут использовать разные виртуальные среды. Чтобы разрешить предыдущий пример конфликтующих требований, приложение A может иметь свою собственную виртуальную среду с установленной версией 1.0, а приложение B имеет другую виртуальную среду с версией 2.0. Если приложение B требует обновления библиотеки до версии 3.0, это не повлияет на среду приложения A.

12.2. Создание виртуальных сред

Модуль, используемый для создания и управления виртуальными средами, называется venv . venv обычно устанавливает самую последнюю версию Python, которая у вас есть. Если у вас есть несколько версий Python в вашей системе, вы можете выбрать конкретную версию Python, запустив ее, python3или любую другую версию, которую хотите.

Чтобы создать виртуальную среду, выберите каталог, в котором вы хотите его разместить, и запустите venv модуль как сценарий с путем к каталогу:

python3 -m venv tutorial-env

Это создаст tutorial-envкаталог, если он не существует, а также создаст внутри него каталоги, содержащие копию интерпретатора Python и различные вспомогательные файлы.

Обычное расположение каталога для виртуальной среды - это .venv. Это имя сохраняет каталог, который обычно скрыт в вашей оболочке и, таким образом, не мешает, давая ему имя, объясняющее, почему каталог существует. Это также предотвращает конфликты с .envфайлами определения переменных среды, которые поддерживаются некоторыми инструментами.

Создав виртуальную среду, вы можете активировать ее.

В Windows запустите:

tutorial-env\Scripts\activate.bat

В Unix или MacOS запустите:

source tutorial-env/bin/activate

(Этот сценарий написан для оболочки bash. Если вы используете оболочки csh или fish , вам следует использовать альтернативные сценарии activate.cshи activate.fishсценарии.)

Активация виртуальной среды изменит приглашение вашей оболочки, чтобы показать, какую виртуальную среду вы используете, и pythonизменит среду так, чтобы запуск предоставил вам конкретную версию и установку Python. Например:

$ source ~/envs/tutorial-env/bin/activate

(tutorial-env) $ python

Python 3.5.1 (default, May 6 2016, 10:59:36)

...

>>> import sys

>>> sys.path

['', '/usr/local/lib/python35.zip', ...,

'~/envs/tutorial-env/lib/python3.5/site-packages']

>>>

12.3. Управление пакетами с помощью pip

Вы можете устанавливать, обновлять и удалять пакеты с помощью программы под названием pip . По умолчанию pipпакеты устанавливаются из индекса пакетов Python, < https://pypi.org >. Вы можете просмотреть указатель пакетов Python, перейдя к нему в своем веб-браузере.

pipимеет ряд подкоманд: «установить», «удалить», «заморозить» и т. д. ( Полную документацию см . в руководстве по установке модулей Python pip ).

Вы можете установить последнюю версию пакета, указав имя пакета:

(tutorial-env) $ python -m pip install novas

Collecting novas

Downloading novas-3.1.1.3.tar.gz (136kB)

Installing collected packages: novas

Running setup.py install for novas

Successfully installed novas-3.1.1.3

Вы также можете установить определенную версию пакета, указав имя пакета, а затем ==номер версии:

(tutorial-env) $ python -m pip install requests==2.6.0

Collecting requests==2.6.0

Using cached requests-2.6.0-py2.py3-none-any.whl

Installing collected packages: requests

Successfully installed requests-2.6.0

Если вы повторно запустите эту команду, pipвы заметите, что запрошенная версия уже установлена, и ничего не сделаете. Вы можете указать другой номер версии, чтобы получить эту версию, или вы можете запустить, чтобы обновить пакет до последней версии:pip install --upgrade

(tutorial-env) $ python -m pip install --upgrade requests

Collecting requests

Installing collected packages: requests

Found existing installation: requests 2.6.0

Uninstalling requests-2.6.0:

Successfully uninstalled requests-2.6.0

Successfully installed requests-2.7.0

pip uninstall за которым следует одно или несколько имен пакетов, они удаляются из виртуальной среды.

pip show отобразит информацию о конкретном пакете:

(tutorial-env) $ pip show requests

---

Metadata-Version: 2.0

Name: requests

Version: 2.7.0

Summary: Python HTTP for Humans.

Home-page: http://python-requests.org

Author: Kenneth Reitz

Author-email: me@kennethreitz.com

License: Apache 2.0

Location: /Users/akuchling/envs/tutorial-env/lib/python3.4/site-packages

Requires:

pip list отобразит все пакеты, установленные в виртуальной среде:

(tutorial-env) $ pip list

novas (3.1.1.3)

numpy (1.9.2)

pip (7.0.3)

requests (2.7.0)

setuptools (16.0)

pip freezeсоздаст аналогичный список установленных пакетов, но в выводе будет использоваться ожидаемый формат . Распространенное соглашение - поместить этот список в файл:pip installrequirements.txt

(tutorial-env) $ pip freeze > requirements.txt

(tutorial-env) $ cat requirements.txt

novas==3.1.1.3

numpy==1.9.2

requests==2.7.0

Затем их requirements.txtможно передать в систему контроля версий и отправить как часть приложения. Затем пользователи могут установить все необходимые пакеты с помощью :install -r

(tutorial-env) $ python -m pip install -r requirements.txt

Collecting novas==3.1.1.3 (from -r requirements.txt (line 1))

...

Collecting numpy==1.9.2 (from -r requirements.txt (line 2))

...

Collecting requests==2.7.0 (from -r requirements.txt (line 3))

...

Installing collected packages: novas, numpy, requests

Running setup.py install for novas

Successfully installed novas-3.1.1.3 numpy-1.9.2 requests-2.7.0

pipесть еще много вариантов. Обратитесь к руководству по установке модулей Python для получения полной документации для pip. Если вы написали пакет и хотите сделать его доступным в индексе пакетов Python, обратитесь к руководству по распространению модулей Python .

=======================================================

НАСТРОЙКИ


#!/usr/bin/python

# GENERATED BY DEBIAN


import sys


# Run the main entry point, similarly to how setuptools does it, but because

# we didn't install the actual entry point from setup.py, don't use the

# pkg_resources API.

from pip import main

if __name__ == '__main__':

sys.exit(main())

-----------------------------------------------------------------------------



#!/usr/bin/python3

# GENERATED BY DEBIAN


import sys


# Run the main entry point, similarly to how setuptools does it, but because

# we didn't install the actual entry point from setup.py, don't use the

# pkg_resources API.

from pip import main

if __name__ == '__main__':

sys.exit(main())---------------

----------------------------------------------------------------------------------------------

from pip._internal.cli.main import main







Так же в этом разделе:
 
MyTetra Share v.0.65
Яндекс индекс цитирования