首頁 > 軟體

Mac中pyenv的安裝與使用教學

2022-02-14 19:01:11

前言

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 openssl@1.1 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安裝使用內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com