Mac中pyenv的安裝與使用教程

前言

pyenv 可在不同 python 版本之間輕松切換,實現 python 環境隔離,且支持自動激活和退出虛擬環境

一、pyenv

1、安裝

方式一:Git Clone

git clone git://github.com/pyenv/pyenv.git ~/.pyenv

bash

echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.bashrc
echo 'export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.bashrc
echo 'export PATH="$PYENV_ROOT/shims:$PATH"' >> ~/.bashrc
echo 'eval "$(pyenv init -)"' >> ~/.bashrc
exec $SHELL -l

zsh

echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.zshrc
echo 'export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.zshrc
echo 'export PATH="$PYENV_ROOT/shims:$PATH"' >> ~/.zshrc
echo 'eval "$(pyenv init -)"' >> ~/.zshrc
exec $SHELL -l

方式二:Homebrew

安裝

brew install pyenv

根據自身環境,將下方內容加到對應文件中: .bashrc / .zshrc

export PYENV_ROOT=/usr/local/var/pyenv
export PATH="$PYENV_ROOT/bin:$PATH"
export PATH="$PYENV_ROOT/shims:$PATH"
if which pyenv > /dev/null; then eval "$(pyenv init -)"; fi

2、驗證

驗證安裝是否成功:

pyenv

3、使用

基本使用

命令 描述
pyenv –version 查看 pyenv 的版本
pyenv versions 羅列當前已安裝的所有 python 環境,如果是當前正在使用的環境,則前面會有個 *
pyenv help 查看幫助
pyenv init 如果輸入 pyenv 之後使用 tab 不補全,可以使用該命令進行初始即可使用補全命令

安裝環境

命令 描述
pyenv install -l 顯示可以安裝的版本列表
pyenv install 版本號 安裝指定版本的 python
pyenv rehash 更新本地數據庫,安裝指定版本的 python 後使用

環境應用

命令 描述
pyenv global 版本號 更改本機版本,重啟不會造成再次更改
pyenv local 版本號 會在當前目錄創建 .python-version 文件,並記錄設置的 python 環境,每次進入該目錄會自動設置成該 python 環境
pyenv shell 版本號 更改當前 shell 下使用的 python 版本,臨時生效,優先級高於 global

二、virtualenv插件

1、安裝

方式一:Git Clone

cd .pyenv/plugins
git clone https://github.com/pyenv/pyenv-virtualenv.git # 安裝virtualenv插件

方式二:Homebrew

brew install pyenv-virtualenv

2、配置

無論使用上述的哪種方式進行的安裝,請根據自身環境,將下方內容加到對應文件中: .bashrc / .zshrc

eval "$(pyenv virtualenv-init -)"

3、使用

基本使用

命令 描述
pyenv virtualenv 3.8.3 env383 創建 3.8.3 版本虛擬環境
pyenv virtualenvs 顯示環境
pyenv activate env383 激活使用指定的虛擬環境
pyenv deactivate 退出當前虛擬環境
rm -rf .pyenv/versions/3.8.3 刪除版本環境
rm -rf .pyenv/versions/env383 刪除虛擬環境

自動激活和退出虛擬環境

在需要使用虛擬環境的目錄(通常是項目目錄)中:

  • 建立一個 .python-version 的文本文件
  • 將虛擬環境名稱(如 env383 )寫在裡面

之後每次進/出該目錄時,虛擬環境都將自動激活/退出。

三、報錯

1、激活指定的虛擬環境時報錯

# 命令
pyenv activate env383

# 報錯信息
Failed to activate virtualenv.

Perhaps pyenv-virtualenv has not been loaded into your shell properly.
Please restart current shell and try again.

別慌,重啟你的終端,或者執行如下命令即可

exec $SHELL -l

2、還是系統版本

如果你用 pyenv versions 查看,明明已經切換成功,但是用 python -V卻還是系統版本。

原因是 pyenv沒有加到 $PATH環境變量裡去,解決辦法如下:

export PYENV_ROOT=~/.pyenv
export PATH=$PYENV_ROOT/shims:$PATH

3、安裝 python報錯

安裝 python報錯,如

pyenv install 3.8.3

報錯內容:

python-build: use [email protected] from homebrew
python-build: use readline from homebrew
Downloading Python-3.8.3.tar.xz...
-> https://www.python.org/ftp/python/3.8.3/Python-3.8.3.tar.xz
Installing Python-3.8.3...
python-build: use readline from homebrew
python-build: use zlib from xcode sdk

BUILD FAILED (OS X 12.0.1 using python-build 20180424)

Inspect or clean up the working tree at /var/folders/cy/8zkx5hys2tsgb1d_x42_r8qc0000gn/T/python-build.20220122174148.1531
Results logged to /var/folders/cy/8zkx5hys2tsgb1d_x42_r8qc0000gn/T/python-build.20220122174148.1531.log

Last 10 log lines:
clang -Wno-unused-result -Wsign-compare -Wunreachable-code -DNDEBUG -g -fwrapv -O3 -Wall -I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include   -I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include   -std=c99 -Wextra -Wno-unused-result -Wno-unused-parameter -Wno-missing-field-initializers -Wstrict-prototypes -Werror=implicit-function-declaration  -I./Include/internal  -I. -I./Include -I/usr/local/opt/readline/include -I/usr/local/opt/readline/include -I/usr/local/var/pyenv/versions/3.8.3/include -I/usr/local/opt/sqlite/include -I/usr/local/opt/readline/include -I/usr/local/opt/readline/include -I/usr/local/var/pyenv/versions/3.8.3/include -I/usr/local/opt/sqlite/include  -DPy_BUILD_CORE_BUILTIN  -c ./Modules/_codecsmodule.c -o Modules/_codecsmodule.o
clang -Wno-unused-result -Wsign-compare -Wunreachable-code -DNDEBUG -g -fwrapv -O3 -Wall -I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include   -I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include   -std=c99 -Wextra -Wno-unused-result -Wno-unused-parameter -Wno-missing-field-initializers -Wstrict-prototypes -Werror=implicit-function-declaration  -I./Include/internal  -I. -I./Include -I/usr/local/opt/readline/include -I/usr/local/opt/readline/include -I/usr/local/var/pyenv/versions/3.8.3/include -I/usr/local/opt/sqlite/include -I/usr/local/opt/readline/include -I/usr/local/opt/readline/include -I/usr/local/var/pyenv/versions/3.8.3/include -I/usr/local/opt/sqlite/include  -DPy_BUILD_CORE_BUILTIN  -c ./Modules/_weakref.c -o Modules/_weakref.o
./Modules/posixmodule.c:9221:15: error: implicit declaration of function 'sendfile' is invalid in C99 [-Werror,-Wimplicit-function-declaration]
        ret = sendfile(in, out, offset, &sbytes, &sf, flags);
              ^
clang -Wno-unused-result -Wsign-compare -Wunreachable-code -DNDEBUG -g -fwrapv -O3 -Wall -I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include   -I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include   -std=c99 -Wextra -Wno-unused-result -Wno-unused-parameter -Wno-missing-field-initializers -Wstrict-prototypes -Werror=implicit-function-declaration  -I./Include/internal  -I. -I./Include -I/usr/local/opt/readline/include -I/usr/local/opt/readline/include -I/usr/local/var/pyenv/versions/3.8.3/include -I/usr/local/opt/sqlite/include -I/usr/local/opt/readline/include -I/usr/local/opt/readline/include -I/usr/local/var/pyenv/versions/3.8.3/include -I/usr/local/opt/sqlite/include  -DPy_BUILD_CORE_BUILTIN  -DPy_BUILD_CORE_BUILTIN -I./Include/internal -c ./Modules/_functoolsmodule.c -o Modules/_functoolsmodule.o
1 error generated.
make: *** [Modules/posixmodule.o] Error 1
make: *** Waiting for unfinished jobs....
1 warning generated.

使用下面的命令安裝即可,註意修改成相應的版本號

CFLAGS="-I$(brew --prefix openssl)/include -I$(brew --prefix bzip2)/include -I$(brew --prefix readline)/include -I$(xcrun --show-sdk-path)/usr/include" LDFLAGS="-L$(brew --prefix openssl)/lib -L$(brew --prefix readline)/lib -L$(brew --prefix zlib)/lib -L$(brew --prefix bzip2)/lib" pyenv install --patch 3.8.3 < <(curl -sSL https://github.com/python/cpython/commit/8ea6353.patch\?full_index\=1)

四、註意

  • 安裝好的版本不做任何修改,我們隻操作虛擬環境,如 env383
  • 可以通過版本來多個虛擬環境,如 env383_1、env383_2
  • 導出當前環境的依賴庫: pip freeze > requirements.txt
  • 導入依賴庫到當前環境: pip install -r requirements.txt

五、相關知識

5.1、pyenv能做什麼

1,基於每個用戶更改全局Python版本

2,對每個項目的Python版本提供支持

3,允許通過環境變量覆蓋Python版本

4,一次搜索多個版本的Python

5.2、pyenv運行

在一個高的級別上,pyenv使用shim可執行文件註入到PATH來攔截Python命令;確定您的應用程序指定瞭哪個Python版本,並將命令傳遞給正確的已安裝Python版本。

5.3、PATH

當運行諸如python或pip等命令時,操作系統將在目錄列表中搜索以查找具有該名稱的可執行文件。此目錄列表位於一個名為PATH的環境變量中,列表中的每個目錄都用冒號分隔:

/usr/local/bin:/usr/bin:/bin

PATH從左到右搜索目錄,因此列表開頭目錄中的匹配可執行文件優先於結尾目錄中的另一個可執行文件。在這個例子中, /usr/local/bin目錄將被搜索的第一個,然後是/usr/bin,然後是/bin。

5.4、shims

pyenv通過在你的PATH前插入shims目錄來工作:

$(pyenv root)/shims:/usr/local/bin:/usr/bin:/bin

Shim是輕量級的可執行文件,它們隻是將命令傳遞給pyenv。因此在安裝瞭pyenv的情況下,運行pip時操作系統將執行以下操作:

1,在PATH中搜索名稱為pip的可執行文件

2,在PATH開頭的shims目錄中,找到名稱為pip的shim文件

3,運行名稱為pip的shime文件,shime將命令傳遞給pyenv

總結

到此這篇關於Mac中pyenv的安裝與使用的文章就介紹到這瞭,更多相關Mac pyenv安裝使用內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: