av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

Python虛擬環(huán)境管理庫-Poetry

簡介

Poetry 是 Python 中的依賴管理和打包工具,它允許你聲明項(xiàng)目所依賴的庫,并為你管理它們。

我們提供的服務(wù)有:成都做網(wǎng)站、網(wǎng)站建設(shè)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、豐南ssl等。為數(shù)千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的豐南網(wǎng)站制作公司

相比于 Pipev,我覺得 poetry 更加清爽,顯示更友好一些,雖然它的打包發(fā)布我們一般不使用,但是其他的虛擬環(huán)境管理也是非常方便的。

安裝

 
 
 
 
  1. pip install poetry 

在控制臺執(zhí)行 poetry -V 命令查看版本

升級

 
 
 
 
  1. poetry self update 

poetry 配置

在使用 poetry 之前我們先進(jìn)行一些設(shè)置,主要是調(diào)整一下虛擬環(huán)境的安裝位置

設(shè)置項(xiàng)

cache-dir

Type: string

緩存目錄配置,使用 poetry 安裝的包源文件都會緩存到這個目錄。以下是系統(tǒng)默認(rèn)目錄:

  • macOS: ~/Library/Caches/pypoetry
  • Windows: C:\Users \AppData\Local\pypoetry\Cache
  • Unix: ~/.cache/pypoetry

installer.parallel

Type: boolean

此配置會被忽略

virtualenvs.create

Type: boolean

默認(rèn)為true,如果當(dāng)前工程的虛擬環(huán)境不存在,就創(chuàng)建一個

virtualenvs.in-project

Type: boolean

  • None:poetry 會在系統(tǒng)特定目錄創(chuàng)建一個.venv目錄,由下面的 path 參數(shù)指定
  • true: poetry 會在項(xiàng)目根目錄創(chuàng)建一個.venv目錄,我推薦這種方式,在項(xiàng)目根目錄創(chuàng)建虛擬環(huán)境,這樣就算移動目錄位置也不影響虛擬環(huán)境的使用
  • false: poetry 將會忽略已存在的.venv目錄

在 Pipev 中如果想把虛擬環(huán)境安裝在當(dāng)前工程根目錄下,則需要通過配置環(huán)境變量 PIPENV_VENV_IN_PROJECT

virtualenvs.path

Type: string

默認(rèn)是{cache-dir}/virtualenvs,虛擬環(huán)境創(chuàng)建的目錄,如果上面的 in-project 為 true,此配置就無效

配置命令

查看所有配置

 
 
 
 
  1. poetry config --list 

查詢單個配置

 
 
 
 
  1. poetry config virtualenvs.path 

添加或者更新配置

 
 
 
 
  1. poetry config virtualenvs.in-project true 

刪除配置

 
 
 
 
  1. poetry config virtualenvs.path --unset 

基本使用

初始化工程

創(chuàng)建新工程

 
 
 
 
  1. poetry new poetry-demo 

已存在的工程

 
 
 
 
  1. cd pre-existing-project 
  2. poetry init 

創(chuàng)建成功后將得到如下目錄:

 
 
 
 
  1. poetry-demo-  
  2. ├── pyproject.toml 
  3. ├── README.rst 
  4. ├── poetry_demo 
  5. │   └── __init__.py 
  6. └── tests 
  7.     ├── __init__.py 
  8.     └── test_poetry_demo.py 

pyproject.toml會是一個非常重要的文件,包含了工程的配置和依賴庫信息,其初始內(nèi)容如下:

 
 
 
 
  1. [tool.poetry] 
  2. name = "poetry-demo" 
  3. version = "0.1.0" 
  4. description = "" 
  5. authors = ["xingxingzaixian "] 
  6.  
  7. [tool.poetry.dependencies] 
  8. python = "^3.7" 
  9.  
  10. [tool.poetry.dev-dependencies] 
  11. pytest = "^5.2" 
  12.  
  13. [build-system] 
  14. requires = ["poetry-core>=1.0.0"] 
  15. build-backend = "poetry.core.masonry.api" 

指定虛擬環(huán)境的 pypi 源

 
 
 
 
  1. [[tool.poetry.source]]
  2. name = "custom" 
  3. url = "https://pypi.tuna.tsinghua.edu.cn/simple" 
  4. default = true 

pyproject.toml 文件配置介紹

tool.poetry

  • name

項(xiàng)目名稱,必選

  • version

項(xiàng)目版本號,默認(rèn)0.1.0,必選

  • description

項(xiàng)目描述,必選

  • license

開源協(xié)議

  • authors

作者,這是一個列表,至少需要包含一個作者信息,必選

  • maintainers

維護(hù)者

  • readme

README文件

  • homepage

項(xiàng)目首頁地址

基本命令

new

 
 
 
 
  1. # 創(chuàng)建新項(xiàng)目 
  2. poetry new project 

init

 
 
 
 
  1. # 初始化已存在的項(xiàng)目 
  2. poetry init project 

可選項(xiàng):

  • --name: 名稱.
  • --description: 描述.
  • --author: 作者.
  • --python: Python 版本.
  • --dependency: 要使用版本約束的包. 格式應(yīng)該為 foo:1.0.0.
  • --dev-dependency: 開發(fā)需求

install

 
 
 
 
  1. poetry install 

install 命令從當(dāng)前項(xiàng)目讀取 pyproject.toml 文件中的依賴性并安裝它們。

如果當(dāng)前目錄中有poetry.lock文件,它將使用其中的確切版本,而不是解析它們。這確保使用庫的每個人都將獲得相同版本的依賴項(xiàng)。如果沒有poetry.lock文件,poetry將在依賴項(xiàng)解析后創(chuàng)建一個。

update

升級安裝包

add

 
 
 
 
  1. poetry add requests  # ==> pip install requests 
  2. poetry add requests@^2.20.0 # 安裝大于2.20.0版本的包 
  3. poetry add "requests=2.20.0" # ==> pip install requests==2.20.0 
  4. poetry add "uvicorn[standard]" # ==> pip install uvicorn[standard] 
  5.  
  6. # 從 git 倉庫安裝 
  7. poetry add git+https://github.com/sdispater/pendulum.git 
  8. poetry add git+ssh://[email protected]/sdispater/pendulum.git 
  9. poetry add git+https://github.com/sdispater/pendulum.git#develop 
  10. poetry add git+https://github.com/sdispater/pendulum.git#2.0.5 
  11.  
  12. # 從本地文件安裝 
  13. poetry add ./my-package/ 
  14. poetry add ../my-package/dist/my-package-0.1.0.tar.gz 
  15. poetry add ../my-package/dist/my_package-0.1.0.whl 

安裝依賴庫并添加到 pyproject.toml,如果沒有指定版本約束,就安裝最新版本

remove

 
 
 
 
  1. poetry remove 

刪除已經(jīng)安裝的依賴包

show

 
 
 
 
  1. # 顯示已經(jīng)安裝的包和版本號 
  2. poetry show  
  3.  
  4. # 顯示非開發(fā)環(huán)境的安裝包 
  5. poetry show --no-dev 
  6.  
  7. # 顯示依賴包的層級關(guān)系 
  8. poetry show --tree 
  9.  
  10. # 顯示已安裝包的當(dāng)前版本和最新版本 
  11. poetry show -l 
  12.  
  13. # 顯示可更新的包 
  14. poetry show -o 

run

這個命令也是一個比較重要的命令,可以讓我們不進(jìn)入虛擬環(huán)境就執(zhí)行虛擬環(huán)境內(nèi)的命令

 
 
 
 
  1. # 查詢虛擬環(huán)境內(nèi)的 Python 版本 
  2. poetry run python -V 
  3.  
  4. # 執(zhí)行虛擬環(huán)境內(nèi)的腳本 
  5. poetry run python test.py 

除了以上可以直接執(zhí)行python命令外,我們還可以配置自定義的腳本命令,在 pyproject.toml 文件中配置 [tool.poetry.scripts],例如配置:

 
 
 
 
  1. [tool.poetry.scripts] 
  2. test = "python test.py" 
  3. serve = "python run.py" 

可以執(zhí)行以下命令:

 
 
 
 
  1. poetry run serve 

shell

 
 
 
 
  1. # 進(jìn)入虛擬環(huán)境內(nèi) 
  2. poetry shell 

check

 
 
 
 
  1. # 檢查 pyproject.toml 配置是否正確 
  2. poetry check 

search

 
 
 
 
  1. # 查詢包 
  2. poetry search requests 

export

 
 
 
 
  1. # 將依賴包導(dǎo)出為 requirements.txt 格式,導(dǎo)出文件名為 requirements.txt 
  2. poetry export -f requirements.txt --output requirements.txt 

env

 
 
 
 
  1. # 使用指定環(huán)境的python 
  2. poetry env use /full/path/to/python 
  3.  
  4. # 如果python在環(huán)境變量中,可以使用一下方式指定 
  5. poetry env use python3.7 
  6.  
  7. # 顯示當(dāng)前虛擬環(huán)境信息 
  8. poetry env info 
  9.  
  10. # 僅顯示虛擬環(huán)境的路徑 
  11. poetry env info --path 
  12.  
  13. # 顯示當(dāng)前工程的所有虛擬環(huán)境列表 
  14. poetry env list 
  15.  
  16. # 顯示當(dāng)前工程的虛擬環(huán)境絕對路徑 
  17. poetry env list --full-path 
  18.  
  19. # 刪除虛擬環(huán)境 
  20. poetry env remove /full/path/to/python 
  21. poetry env remove python3.7 

cache

 
 
 
 
  1. # 查看緩存列表 
  2. poetry cache list 
  3.  
  4. # 清除指定的緩存 
  5. poetry cache clear  
  6.  
  7. # 清除所有緩存 
  8. poetry cache clear --all 

依賴包的版本關(guān)系

在 poetry 中支持類似 webpack 里面的版本關(guān)系,例如 ^2.3.0、~2.3.0,這是什么對應(yīng)關(guān)系呢


網(wǎng)頁題目:Python虛擬環(huán)境管理庫-Poetry
網(wǎng)頁URL:http://uogjgqi.cn/article/cdssidh.html

掃二維碼與項(xiàng)目經(jīng)理溝通

我們在微信上24小時(shí)期待你的聲音

解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流