2017年7月11日 星期二

[Python 文章收集] Virtual Environments

Source From Here 
Preface 
A Virtual Environment is a tool to keep the dependencies required by different projects in separate places, by creating virtual Python environments for them. It solves the “Project X depends on version 1.x but, Project Y needs 4.x” dilemma, and keeps your global site-packages directory clean and manageable. For example, you can work on a project which requires Django 1.10 while also maintaining a project which requires Django 1.8. 

virtualenv 
virtualenv is a tool to create isolated Python environments. virtualenv creates a folder which contains all the necessary executables to use the packages that a Python project would need. 
# pip install virtualenv
# virtualenv --version
15.1.0

Basic Usage 

1. Create a virtual environment for a project: 
# cd my_project_folder/
# virtualenv my_project
Using base prefix '/usr/local'
New python executable in /root/Tmp/my_project_folder/my_project/bin/python3.5
Also creating executable in /root/Tmp/my_project_folder/my_project/bin/python
Installing setuptools, pip, wheel...done.

virtualenv my_project will create a folder in the current directory which will contain the Python executable files, and a copy of the pip library which you can use to install other packages. The name of the virtual environment (in this case, it was my_project) can be anything; omitting the name will place the files in the current directory instead. 

This creates a copy of Python in whichever directory you ran the command in, placing it in a folder named my_project. You can also use the Python interpreter of your choice (like python2.7). 
// -p PYTHON_EXE, --python=PYTHON_EXE: The Python interpreter to use
# virtualenv -p /usr/bin/python2.7 my_project

or change the interpreter globally with an env variable in ~/.bashrc
# export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python2.7


2. To begin using the virtual environment, it needs to be activated: 
# env > origin_env // Save original env variables
# source my_project/bin/activate
# env > new_env
# diff origin_env new_env
7a8
OLDPWD=/root/Tmp/my_project_folder/my_project
10a12
VIRTUAL_ENV=/root/Tmp/my_project_folder/my_project
12c14
PATH=/usr/lib/jvm/java-1.8.0-openjdk/bin:/opt/groovy/bin:/root/apache-tomcat-7.0.61/bin:/opt/maven/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/opt/gradle/latest/bin:/root/bin
---
PATH=/root/Tmp/my_project_folder/my_project/bin:/usr/lib/jvm/java-1.8.0-openjdk/bin:/opt/groovy/bin:/root/apache-tomcat-7.0.61/bin:/opt/maven/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/opt/gradle/latest/bin:/root/bin
15a18
PS1=(my_project) [\u@\h \W]\$
25d27
OLDPWD=/root/Tmp/my_project_folder/my_project

The name of the current virtual environment will now appear on the left of the prompt (e.g. (my_project)Your-Computer:your_project UserName$) to let you know that it’s active. From now on, any package that you install using pip will be placed in the my_project folder, isolated from the global Python installation

Install packages as usual, for example (requests): 
# pip install requests
# p3 -c "import requests; print(requests.__version__)"
2.18.1

3. If you are done working in the virtual environment for the moment, you can deactivate it: 
# deactivate
# p3 -c "import requests; print(requests.__version__)" // The host python is installed with requests version 2.13.0
2.13.0

This puts you back to the system’s default Python interpreter with all its installed libraries. To delete a virtual environment, just delete its folder. (In this case, it would be rm -rf my_project.) After a while, though, you might end up with a lot of virtual environments littered across your system, and its possible you’ll forget their names or where they were placed. 

Other Notes 
Running virtualenv with the option --no-site-packages will not include the packages that are installed globally. This can be useful for keeping the package list clean in case it needs to be accessed later. (This is the default behavior for virtualenv 1.7 and later.) In order to keep your environment consistent, it’s a good idea to “freeze” the current state of the environment packages. To do this, run 
// freeze: Output installed packages in requirements format.
# pip freeze > requirements.txt
# tail requirements.txt
toolz==0.8.2
tqdm==4.11.2
traitlets==4.3.2
ujson==1.35
virtualenv==15.1.0
wcwidth==0.1.7
websocket-client==0.44.0
Werkzeug==0.12.2
wrapt==1.10.10
xlrd==1.0.0

This will create a requirements.txt file, which contains a simple list of all the packages in the current environment, and their respective versions. You can see the list of installed packages without the requirements format using “pip list”. Later it will be easier for a different developer (or you, if you need to re-create the environment) to install the same packages using the same versions: 
# pip install -r requirements.txt

This can help ensure consistency across installations, across deployments, and across developers. Lastly, remember to exclude the virtual environment folder from source control by adding it to the ignore list. 

virtualenvwrapper 
virtualenvwrapper provides a set of commands which makes working with virtual environments much more pleasant. It also places all your virtual environments in one place. To install (make sure virtualenv is already installed): 
# pip install virtualenvwrapper
# export WORKON_HOME=~/Envs
# source /usr/local/bin/virtualenvwrapper.sh

(Full virtualenvwrapper install instructions.

Basic Usage 

1. Create a virtual environment: 
# mkvirtualenv my_project

This creates the my_project folder inside ~/Envs

2. Work on a virtual environment: 
# workon my_project

Alternatively, you can make a project, which creates the virtual environment, and also a project directory inside $PROJECT_HOME, which is cd -ed into when you workon myproject. 
# mkproject myproject

virtualenvwrapper provides tab-completion on environment names. It really helps when you have a lot of environments and have trouble remembering their names. 

workon also deactivates whatever environment you are currently in, so you can quickly switch between environments. 

3. Deactivating is still the same: 
# deactivate


4. To delete: 
# rmvirtualenv venv


Other useful commands 
* lsvirtualenv: List all of the environments.
* cdvirtualenv: Navigate into the directory of the currently activated virtual environment, so you can browse its site-packages, for example.
* cdsitepackages: Like the above, but directly into site-packages directory.
* lssitepackages: Shows contents of site-packages directory.

Full list of virtualenvwrapper commands. 

virtualenv-burrito 
With virtualenv-burrito, you can have a working virtualenv + virtualenvwrapper environment in a single command. 

autoenv 
When you cd into a directory containing a .env, autoenv automagically activates the environment. Install it: 
# git clone git://github.com/kennethreitz/autoenv.git ~/.autoenv
# echo 'source ~/.autoenv/activate.sh' >> ~/.bashrc


Supplement 
Python 3 Tutorial 第七堂(1)pip 與 venv

沒有留言:

張貼留言

[Git 常見問題] error: The following untracked working tree files would be overwritten by merge

  Source From  Here 方案1: // x -----删除忽略文件已经对 git 来说不识别的文件 // d -----删除未被添加到 git 的路径中的文件 // f -----强制运行 #   git clean -d -fx 方案2: 今天在服务器上  gi...