千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 4個(gè)Python項(xiàng)目管理與構(gòu)建工具,建議收藏

4個(gè)Python項(xiàng)目管理與構(gòu)建工具,建議收藏

來源:千鋒教育
發(fā)布人:syq
時(shí)間: 2022-09-16 11:02:38 1663297358

  Python 歷時(shí)這么久以來至今還未有一個(gè)事實(shí)上標(biāo)準(zhǔn)的項(xiàng)目管理及構(gòu)建工具,以至于造成 Python 項(xiàng)目的結(jié)構(gòu)與構(gòu)建方式五花八門。這或許是體現(xiàn)了 Python 的自由意志。

Python項(xiàng)目管理與構(gòu)建工具

  不像 Java 在經(jīng)歷了最初的手工構(gòu)建,到半自動(dòng)化的 Ant, 再到 Maven 基本就是事實(shí)上的標(biāo)準(zhǔn)了。其間 Maven 還接受了其他的 Gradle(Android 項(xiàng)目主推), SBT(主要是 Scala 項(xiàng)目), Ant+Ivy, Buildr 等的挑戰(zhàn),但都很難撼動(dòng) Maven 的江湖地位,而且其他的差不多遵循了 Maven 的目錄布局。

  回到 Python,產(chǎn)生過 pip, pipenv, conda 那樣的包管理工具,但對(duì)項(xiàng)目的目錄布局沒有任何約定。

  關(guān)于構(gòu)建很多還是延續(xù)了傳統(tǒng)的 Makefile 的方式,再就是加上 setup.py 和 build.py 用程序代碼來進(jìn)行安裝與構(gòu)建。關(guān)于項(xiàng)目目錄布局,有做成項(xiàng)目模板的,然后做成工具來應(yīng)用項(xiàng)目模板。

  下面大概瀏覽一下四個(gè)工具的使用

  CookieCutter

  PyScaffold

  PyBuilder

  Poetry

  CookieCutter 一個(gè)經(jīng)典的 Python 項(xiàng)目目錄結(jié)構(gòu)

1

  最后由 cookiecutter 生成的項(xiàng)目模板是下面的樣子:

2

  這大概是當(dāng)前比較流行的目錄結(jié)構(gòu)的主體框架,主要元素是:

3

  項(xiàng)目 sample 目錄中重復(fù) sample 目錄中放置 Python 源文件,tests 目錄中是測試文件,再加一個(gè) docs 目錄放文檔,README.rst, 其他的用于構(gòu)建的 setup, setup.cfg 和 Makefile 文件。

  這其實(shí)是一個(gè)很經(jīng)典的 Python 項(xiàng)目結(jié)構(gòu),接下來的構(gòu)建就用 make 命令了,輸入 make 會(huì)看到定義在 Makefile 文件中的指令

4

  為使用上面的構(gòu)建過程,需要安裝相應(yīng)的包,如 tox, wheel, coverage, sphinx, flake8, 它們都可以通過 pip 來安裝。之后就可以 make test, make coverage, make docs,make dist 等。其中 make docs 可以生成一個(gè)很漂亮的 Web 文檔。

  PyScaffold 創(chuàng)建一個(gè)項(xiàng)目

  PyScaffold 顧名思義,它是一個(gè)用來創(chuàng)建 Python 項(xiàng)目腳手架的工具,安裝和使用:

5

  這樣創(chuàng)建了一個(gè) Python 項(xiàng)目,目錄結(jié)構(gòu)與前面 cookiecutter 所選的模板差不多,只不過它把源文件放在了 src 目錄,而非 sample 目錄。

6

  整個(gè)項(xiàng)目的構(gòu)建就要用 tox 這個(gè)工具了。tox 是一個(gè)自動(dòng)化測試和構(gòu)建工具,它在構(gòu)建過程中可創(chuàng)建 Python 虛擬環(huán)境,這讓測試和構(gòu)建能有一個(gè)干凈的環(huán)境。

  tox -av 能顯示出定義在 tox.ini 中所有的任務(wù):

7

  要執(zhí)行哪個(gè)命令便用 tox -e build, tox -e docs 等

  在我體驗(yàn) tox 命令過程中,每一步好像都比較慢,應(yīng)該是創(chuàng)建虛擬機(jī)要花些時(shí)間。

  PyBuilder

  最好再看另一個(gè)構(gòu)建工具 PyBuilder, 它所創(chuàng)建出的目錄結(jié)構(gòu)很接近于 Maven, 下面來瞧瞧

8

  完后看下它的目錄結(jié)構(gòu):

9

  構(gòu)建過程仍然是用 pyb 命令,可用 pyb -h 查看幫助,pyb -t 列出所有的任務(wù), PyBuilder 的任務(wù)是以插件的方式加入的,插件配置在 build.py 文件中。

10

  PyBuilder 也是在構(gòu)建或測試之前創(chuàng)建虛擬環(huán)境, 從 0.12.9 版開始可通過參數(shù) --no-venvs 跳過創(chuàng)建虛擬環(huán)境這一步。使用了 --no-venvs 的話 Python 代碼將會(huì)在運(yùn)行 pyb 的當(dāng)前 Python 環(huán)境中執(zhí)行,所需的依賴將要手工安裝。

  項(xiàng)目的依賴也要定義在 build.py 文件中

11

  隨后在執(zhí)行 pyb 創(chuàng)建虛擬環(huán)境時(shí)就會(huì)安裝上面的依賴,并在其中運(yùn)行測試與構(gòu)建。

  Poetry

  最后一個(gè) Poetry, 感覺這是一個(gè)更為成熟,項(xiàng)目活躍度也更高的 Python 構(gòu)建,它有著更強(qiáng)大的信賴管理功能,用 poetry add boto3 就能添加依賴,poetry show --tree 顯示出依賴樹??聪氯绾伟惭b及創(chuàng)建一個(gè)項(xiàng)目

12

  它創(chuàng)建的項(xiàng)目比上面都簡單

13

  如果給 poetry new 帶上 --src 參數(shù),那么源文件目錄 sample 會(huì)放在 src 目錄下,即 sample/src/sample.

  poetry init 會(huì)在當(dāng)前目錄中生成 pyproject.toml 文件,目錄等的生成需手動(dòng)完成。

  它不關(guān)注文檔的生成,代碼規(guī)范的檢查,代碼覆蓋率都沒有。它的項(xiàng)目配置更集中,全部在 pyproject.toml 文件中,toml 是什么呢?它是一種配置文件的格式 Tom's Obvious, Minimal Language

  pyproject.toml 有些類似 NodeJS 的 package.json 文件,比如 poetry add, poetry install 命令的行

14

  其他主要的

15

  poetry run 能執(zhí)行任何系統(tǒng)命令,只是它會(huì)在它要的虛擬環(huán)境中執(zhí)行。所以可以想見,poetry 的項(xiàng)目要生成文檔或覆蓋率都必須用 poetry run ... 命令來支持 sphinx, coverage 或 flake8。

  在 sample 目錄(與 pyproject.toml 文件平級(jí))中創(chuàng)建文件 my_module.py, 內(nèi)容為

16

  然后在 pyproject.toml 中寫上

17

  再執(zhí)行

18

  就會(huì)輸出 "hello poetry"。 通過對(duì)以上四個(gè)工具的認(rèn)識(shí),項(xiàng)目結(jié)構(gòu)的復(fù)雜度由 cookiecutter-pyproject -> PyScaffold -> PyBuilder -> Poetry 依次降低,使用的難度大略也是相同的順序。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
抖店入駐收費(fèi)多少?開抖店費(fèi)用是多少?

如果要開通抖音小店,需要先把抖音賬號(hào)開通商品櫥窗功能。入駐之后,可以選擇頭條賬號(hào)、抖音賬號(hào)、火山賬號(hào)任一類型注冊(cè)或登錄。那開個(gè)抖店要多...詳情>>

2023-09-19 07:50:26
想做直播帶貨的貨源哪里來?怎么找貨源?

現(xiàn)如今直播推廣的方式是非?;鸬模兄浅6嗟馁u家都是利用直播推廣店鋪產(chǎn)品,效果也是非常不錯(cuò)。但很多賣家想要了解現(xiàn)在直播帶貨的話什么產(chǎn)品...詳情>>

2023-09-19 07:47:16
適合三農(nóng)領(lǐng)域的名字?有何技巧?

現(xiàn)在在抖音上很多博主會(huì)選擇直播來賺取更多的流量以及利潤,直播間的東西也有很多讓消費(fèi)者信任并且喜歡的,而且隨著越來越多人直播,很多農(nóng)產(chǎn)品...詳情>>

2023-09-19 07:06:05
抖店商品發(fā)布違規(guī)怎么申訴?有何規(guī)則?

抖店服務(wù)市場服務(wù)商發(fā)布違禁信息如何處理?情節(jié)嚴(yán)重程度判定原則:違規(guī)嚴(yán)重等級(jí)主要通過服務(wù)商違規(guī)次數(shù)、造成后果的嚴(yán)重程度、獲利或?qū)е聯(lián)p失的...詳情>>

2023-09-19 06:59:55
“泛垂直起號(hào)”可能是2023年最高效的起號(hào)方式

這可能是明年最好用的旗號(hào)方式了,今天教大家一個(gè)很野,但是可以讓你三天漲1000粉的偏方。去年前年啊,每個(gè)人都教你,誰知七號(hào)對(duì)著自己的產(chǎn)品拍...詳情>>

2023-09-19 06:37:38
開班信息
北京校區(qū)
  • 北京校區(qū)
  • 大連校區(qū)
  • 廣州校區(qū)
  • 成都校區(qū)
  • 杭州校區(qū)
  • 長沙校區(qū)
  • 合肥校區(qū)
  • 南京校區(qū)
  • 上海校區(qū)
  • 深圳校區(qū)
  • 武漢校區(qū)
  • 鄭州校區(qū)
  • 西安校區(qū)
  • 青島校區(qū)
  • 重慶校區(qū)
  • 太原校區(qū)
  • 沈陽校區(qū)
  • 南昌校區(qū)
  • 哈爾濱校區(qū)