亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PyCharm+Pipenv虛擬環(huán)境開發(fā)和依賴管理的教程詳解

 更新時間:2020年04月16日 10:04:26   作者:以王姓自居  
這篇文章主要介紹了PyCharm+Pipenv虛擬環(huán)境作開發(fā)和依賴管理的教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

hello,小伙伴們大家好,今天給大家介紹的開源項目是Python虛擬環(huán)境管理工具,Pipenv是Python官方推薦的包管理工具。可以說,它集成了virtualenv, pippyenv三者的功能。其目的旨在集合了所有的包管理工具的長處,如: npm, yarn, composer等的優(yōu)點。

Pipenv試圖解決的問題是多方面的:

我們不需要再手動創(chuàng)建虛擬環(huán)境,Pipenv會自動為我們創(chuàng)建,它會在某個特定的位置創(chuàng)建一個 virtualenv 環(huán)境,然后調(diào)用 pipenv shell 命令切換到虛擬環(huán)境。使用 requirements.txt 可能會導致一些問題,所以 Pipenv 使用 PipfilePipfile.lock 來替代之,而且 Pipfile 如果不存在的話會自動創(chuàng)建,而且在安裝、升級、移除依賴包的時候會自動更新 PipfilePipfile.lock 文件。哈希值隨處可見。安全。自動公開安全漏洞。讓您深入了解依賴關系圖(例如$ pipenv graph)。隨時查看圖形化的依賴關系??赏ㄟ^自動加載 .env 讀取環(huán)境變量,簡化開發(fā)流程。

安裝Pipenv

MacOS

$ brew install pipenv

Debian

$ sudo apt install pipenv

Fedora

$ sudo dnf install pipenv

假如你電腦上有多個Python版本,你可以指定Python版本安裝

$ python3 -m pip install pipenv

常用命令

$ pipenv
Usage: pipenv [OPTIONS] COMMAND [ARGS]...

Options:
 --where  顯示項目文件所在路徑
 --venv  顯示虛擬環(huán)境實際文件所在路徑
 --py  顯示虛擬環(huán)境Python解釋器所在路徑
 --envs  顯示虛擬環(huán)境的選項變量
 --rm  刪除虛擬環(huán)境
 --bare  最小化輸出
 --completion 完整輸出
 --man  顯示幫助頁面
 --three / --two 使用Python 3/2創(chuàng)建虛擬環(huán)境(注意本機已安裝的Python版本)
 --python TEXT 指定某個Python版本作為虛擬環(huán)境的安裝源
 --site-packages 附帶安裝原Python解釋器中的第三方庫
 --jumbotron An easter egg, effectively.
 --version 版本信息
 -h, --help 幫助信息

命令參數(shù)

Commands:
 check 檢查安全漏洞
 graph 顯示當前依賴關系圖信息
 install 安裝虛擬環(huán)境或者第三方庫
 lock 鎖定并生成Pipfile.lock文件
 open 在編輯器中查看一個庫
 run 在虛擬環(huán)境中運行命令
 shell 進入虛擬環(huán)境
 uninstall 卸載一個庫
 update 卸載當前所有的包,并安裝它們的最新版本

基本使用

我們可以創(chuàng)建一個項目,名稱 PipenvTest,然后新建一個 Python 腳本,例如叫 tst_env.py,內(nèi)容為:

import django
print(django.get_version())

結(jié)果如下:

1.12

我們可以看到系統(tǒng)安裝的 Django 版本是 1.12。但是我們想要本項目基于 Django 2.x 開發(fā),當然我們可以選擇將系統(tǒng)的 Django 版本升級,但這樣又可能會影響其他的項目的運行,所以這并不是一個好的選擇。為了不影響系統(tǒng)環(huán)境的 Django 版本,所以我們可以用 Pipenv 來創(chuàng)建一個虛擬環(huán)境。

在該目錄下,輸入 pipenv 命令即可查看命令的完整用法:

Usage: pipenv [OPTIONS] COMMAND [ARGS]...

Options:
 --update  Update Pipenv & pip to latest.
 --where  Output project home information.
 --venv  Output virtualenv information.
 --py  Output Python interpreter information.
 --envs  Output Environment Variable options.
 --rm  Remove the virtualenv.
 --bare  Minimal output.
 --completion Output completion (to be eval'd).
 --man  Display manpage.
 --three / --two Use Python 3/2 when creating virtualenv.
 --python TEXT Specify which version of Python virtualenv should use.
 --site-packages Enable site-packages for the virtualenv.
 --jumbotron An easter egg, effectively.
 --version Show the version and exit.
 -h, --help Show this message and exit.

Usage Examples:
 Create a new project using Python 3.6, specifically:
 $ pipenv --python 3.6

 Install all dependencies for a project (including dev):
 $ pipenv install --dev

 Create a lockfile containing pre-releases:
 $ pipenv lock --pre

 Show a graph of your installed dependencies:
 $ pipenv graph

 Check your installed dependencies for security vulnerabilities:
 $ pipenv check

 Install a local setup.py into your virtual environment/Pipfile:
 $ pipenv install -e .

Commands:
 check Checks for security vulnerabilities and against PEP 508 markers
  provided in Pipfile.
 graph Displays currently–installed dependency graph information.
 install Installs provided packages and adds them to Pipfile, or (if none
  is given), installs all packages.
 lock Generates Pipfile.lock.
 open View a given module in your editor.
 run Spawns a command installed into the virtualenv.
 shell Spawns a shell within the virtualenv.
 uninstall Un-installs a provided package and removes it from Pipfile.
 update Uninstalls all packages, and re-installs package(s) in [packages]
  to latest compatible versions.

創(chuàng)建虛擬環(huán)境

第一步首先驗證一下當前的項目是沒有創(chuàng)建虛擬環(huán)境的,調(diào)用如下命令:

$ pipenv --venv

結(jié)果如下

No virtualenv has been created for this project yet!
Aborted!

這說明當前的項目尚未創(chuàng)建虛擬環(huán)境,接下來我們利用 Pipenv 來創(chuàng)建一個虛擬環(huán)境:

$ pipenv --three
或者
$ pipenv install --python 3.6

創(chuàng)建一個 Python3 的虛擬環(huán)境,–-three 代表創(chuàng)建一個 Python3 版本的虛擬環(huán)境,–-python 則可以指定特定的 Python 版本,當然如果指定了 --two 或者 --three 選項參數(shù),則會使用 python2 或者 python3 的版本安裝,否則將使用默認的 python 版本來安裝。但前提你的系統(tǒng)必須裝有該版本的 Python 才可以。

當然也可以指定準確的版本信息:

$ pipenv install --python 3
$ pipenv install --python 3.6
$ pipenv install --python 2.7.14

pipenv 會自動掃描系統(tǒng)尋找合適的版本信息,如果找不到的話,同時又安裝了 pyenv 的話,則會自動調(diào)用 pyenv 下載對應版本的 python, 否則會報錯。

這時候在當前 new_env 環(huán)境下生成 Pipfile 和 Pipfile.lock 兩個環(huán)境初始化文件。

接下來我們可以切換到該虛擬環(huán)境下執(zhí)行命令,執(zhí)行如下命令即可:

$ pipenv shell

使用Pipenv來安裝第三方包

$ pipenv install urllib3

此時,Pipfile 里有最新安裝的包文件的信息,如名稱、版本等。用來在重新安裝項目依賴或與他人共享項目時,你可以用 Pipfile 來跟蹤項目依賴。

Pipfile 是用來替代原來的 requirements.txt 的,內(nèi)容類似下面這樣。source 部分用來設置倉庫地址,packages 部分用來指定項目依賴的包,dev-packages 部分用來指定開發(fā)環(huán)境需要的包,這樣分開便于管理。

$ cat Pipfile

[[source]]
url = "https://pypi.org/simple"
verify_ssl = true
name = "pypi"

[packages]
"urllib3" = "*"

[dev-packages]

[requires]
python_version = "3.6"

Pipfile.lock 則包含你的系統(tǒng)信息,所有已安裝包的依賴包及其版本信息,以及所有安裝包及其依賴包的 Hash 校驗信息。

$ Pipfile.lock
{
 "_meta": {
 "hash": {
  "sha256": "af58f3510cb613d4d9241128f9a0ceb9bb936ad907543e23ad8317011dcb6715"
 },
 "pipfile-spec": 6,
 "requires": {
  "python_version": "3.6"
 },
 "sources": [
  {
  "name": "pypi",
  "url": "https://pypi.org/simple",
  "verify_ssl": true
  }
 ]
 },
 "default": {  
  "urllib3": {
  "hashes": [
  "sha256:a68ac5e15e76e7e5dd2b8f94007233e01effe3e50e8daddf69acfd81cb686baf",
  "sha256:b5725a0bd4ba422ab0e66e89e030c806576753ea3ee08554382c14e685d117b5"
  ],
  "index": "pypi",
  "version": "==1.23"
 }
 },
 "develop": {}
}

那么到這里有小伙伴可能就會問了, Pipfile 和 Pipfile.lock 有什么用呢?

Pipfile 其實一個 TOML 格式的文件,標識了該項目依賴包的基本信息,還區(qū)分了生產(chǎn)環(huán)境和開發(fā)環(huán)境的包標識,作用上類似 requirements.txt 文件,但是功能更為強大。Pipfile.lock 詳細標識了該項目的安裝的包的精確版本信息、最新可用版本信息和當前庫文件的 hash 值,顧明思義,它起了版本鎖的作用,可以注意到當前 Pipfile.lock 文件中的 Django 版本標識為 ==2.0.2,意思是當前我們開發(fā)時使用的就是 2.0.2 版本,它可以起到版本鎖定的功能。

舉個例子,剛才我們安裝了 Django 2.0.2 的版本,即目前(2018.2.27)的最新版本。但可能 Django 以后還會有更新,比如某一天 Django 更新到了 2.1 版本,這時如果我們想要重新部署本項目到另一臺機器上,假如此時不存在 Pipfile.lock 文件,只存在 Pipfile文件,由于 Pipfile 文件中標識的 Django 依賴為 django = “*”,即沒有版本限制,它會默認安裝最新版本的 Django,即 2.1,但由于 Pipfile.lock 文件的存在,它會根據(jù) Pipfile.lock 來安裝,還是會安裝 Django 2.0.2,這樣就會避免一些庫版本更新導致不兼容的問題。

Rember:任何情況下都不要手動修改 Pipfile.lock 文件!

常用命令

我們可以使用 –-venv 參數(shù)來獲得虛擬環(huán)境路徑:

$ pipenv --venv
/Users/kennethreitz/.local/share/virtualenvs/test-Skyy4vre

項目路徑

$ pipenv --where
/Users/kennethreitz/Library/Mobile Documents/com~apple~CloudDocs/repos/kr/pipenv/test

找到Python解釋器:

$ pipenv --py
/Users/kennethreitz/.local/share/virtualenvs/test-Skyy4vre/bin/python

安裝指定軟件包:

$ pipenv install urllib3==1.22

安裝開發(fā)環(huán)境下的包:
通常有一些Python包只在你的開發(fā)環(huán)境中需要,而不是在生產(chǎn)環(huán)境中,例如單元測試包。 Pipenv使用--dev標志區(qū)分兩個環(huán)境。
加 --dev 表示包括 Pipfile 的 dev-packages 中的依賴。

$ pipenv install django --dev
Installing pytest...
...
Adding pytest to Pipfile's [dev-packages]...

django庫現(xiàn)在將只在開發(fā)虛擬環(huán)境中使用。如果你要在你的生產(chǎn)環(huán)境中安裝你的項目:

pipenv install

這不會安裝django包。

但是,如果有一個開發(fā)人員將你的項目克隆到自己的開發(fā)環(huán)境中,他們可以使用--dev標志,將django也安裝:

pipenv install --dev

也就是說一個--dev參數(shù),幫你在同一個虛擬環(huán)境中又區(qū)分出了開發(fā)和非開發(fā)環(huán)境。

顯示依賴關系圖:

$ pipenv graph
requests==2.18.4
 - certifi [required: >=2017.4.17, installed: 2017.7.27.1]
 - chardet [required: >=3.0.2,<3.1.0, installed: 3.0.4]
 - idna [required: >=2.5,<2.7, installed: 2.6]
 - urllib3 [required: <1.23,>=1.21.1, installed: 1.22]

生成一個鎖文件:

$ pipenv lock
Assuring all dependencies from Pipfile are installed...
Locking [dev-packages] dependencies...
Locking [packages] dependencies...
Note: your project now has only default [packages] installed.
To install [dev-packages], run: $ pipenv install --dev

卸載第三方包:

$ pipenv uninstall urllib3 
或者
$ pipenv uninstall --all

更新安裝包

$ pipenv update urllib3
$ pipenv update # 更新所有安裝包

檢查軟件包的完整性
你是否擔心已安裝的軟件包有沒有安全漏洞?沒關系,pipenv 可以幫你檢查,運行下面的命令:

$ pipenv check
Checking PEP 508 requirements…
Passed!
Checking installed package safety…
All good!

產(chǎn)生 Pipfile.lock
有時候可能 Pipfile.lock 文件不存在或被刪除了,這時候我們可以使用如下命令生成:

$ pipenv lock

以上便是一些常用的 Pipenv 命令,如果要查看更多用法可以參考其官方文檔:https://docs.pipenv.org/#pipenv-usage。

修改下載源Pipenv

如果你覺得在使用pipenv install安裝的過程中下載比較慢可以指下載源:

[[source]]
name = "pypi"
url = "https://pypi.tuna.tsinghua.edu.cn/simple/"
verify_ssl = true

[dev-packages]

[packages]
requests = "*"
paho-mqtt = "*"
pymongo = "*"
can = "*"
crypto = "*"
gvent = "*"
gevent = "*"

[requires]
python_version = "3.7"

只需要修改Pipfile即可。

Pip下載源

阿里: http://mirrors.aliyun.com/pypi/simple/
豆瓣: http://pypi.douban.com/simple/
清華: https://pypi.tuna.tsinghua.edu.cn/simple

PyCharm配置Pipenv

添加Python解釋器

選擇Pipenv 虛擬環(huán)境
Base interpreter為本機系統(tǒng)中的python解釋器路徑
Pipenv executable表示pipenv,命令的環(huán)境變量路徑

在項目下選擇剛剛新建好的Pipenv名稱。

項目地址:https://github.com/pypa/pipenv

總結(jié)

到此這篇關于PyCharm+Pipenv虛擬環(huán)境開發(fā)和依賴管理的文章就介紹到這了,更多相關PyCharm+Pipenv虛擬環(huán)境作開發(fā)和依賴管理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • python基于socket函數(shù)實現(xiàn)端口掃描

    python基于socket函數(shù)實現(xiàn)端口掃描

    這篇文章主要為大家詳細介紹了python基于socket函數(shù)實現(xiàn)端口掃描,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • python中hasattr()、getattr()、setattr()函數(shù)的使用

    python中hasattr()、getattr()、setattr()函數(shù)的使用

    這篇文章主要介紹了python中hasattr()、getattr()、setattr()函數(shù)的使用方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • Python正則表達式使用經(jīng)典實例

    Python正則表達式使用經(jīng)典實例

    本文給大家總結(jié)了17種python正則表達式使用經(jīng)典實例,非常不錯具有參考借鑒價值,感興趣的朋友一起學習吧
    2016-06-06
  • 詳解Python常用的魔法方法

    詳解Python常用的魔法方法

    在Python中,所有以“__”雙下劃線包起來的方法,都統(tǒng)稱為“Magic Method”,中文稱『魔術方法』,例如類的初始化方法 __init__ ,Python中所有的魔術方法均在官方文檔中有相應描述,今天給大家整理了本篇文章,需要的朋友可以參考下
    2021-06-06
  • 在pytorch中計算準確率,召回率和F1值的操作

    在pytorch中計算準確率,召回率和F1值的操作

    這篇文章主要介紹了在pytorch中計算準確率,召回率和F1值的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Pycharm社區(qū)版創(chuàng)建Flask項目的實現(xiàn)步驟

    Pycharm社區(qū)版創(chuàng)建Flask項目的實現(xiàn)步驟

    本文主要介紹了Pycharm社區(qū)版創(chuàng)建Flask項目,包括設置Python環(huán)境、安裝Flask庫以及創(chuàng)建基本的項目結(jié)構(gòu),具有一定的參考價值,感興趣的可以了解一下
    2024-06-06
  • Python進階多線程爬取網(wǎng)頁項目實戰(zhàn)

    Python進階多線程爬取網(wǎng)頁項目實戰(zhàn)

    這篇文章主要為大家介紹了Python進階,Python多線程爬取網(wǎng)頁項目實戰(zhàn)的示例呈現(xiàn)步驟,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-10-10
  • 基于Python實現(xiàn)n-gram文本生成的示例代碼

    基于Python實現(xiàn)n-gram文本生成的示例代碼

    N-gram是自然語言處理中常用的技術,它可以用于文本生成、語言模型訓練等任務,本文主要介紹了如何在Python中實現(xiàn)n-gram文本生成,需要的可以參考下
    2024-01-01
  • pytorch之torch_scatter.scatter_max()用法

    pytorch之torch_scatter.scatter_max()用法

    這篇文章主要介紹了pytorch之torch_scatter.scatter_max()用法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 梯度下降法介紹及利用Python實現(xiàn)的方法示例

    梯度下降法介紹及利用Python實現(xiàn)的方法示例

    梯度下降算法是一個很基本的算法,在機器學習和優(yōu)化中有著非常重要的作用,下面這篇文章主要給大家介紹了關于利用Python實現(xiàn)梯度下降法的相關資料,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-07-07

最新評論