成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

特別推薦!優化​Python開發環境的幾個技巧,實現自動化讓你遠離煩惱

開發 后端 開發工具 自動化
當一個項目依賴于同一函數庫的不同版本時,常常發生版本沖突。修復以上問題消耗大量時間,還經常導致其他項目出現問題。必須找到避免這類問題的解決方式,為編寫代碼提供便利。

用Python編代碼體驗極佳,并隨著新版本的發布越來越好!對于我而言,Python提供的大量免費函數庫、高可讀性的程序和新引入的類型注釋讓我沉迷其中無法自拔。然而,數據科學家特別容易使自己的Jupyter notebook變得龐大而雜亂,或者寫出一些難以理解的python文件。此外,當一個項目依賴于同一函數庫的不同版本時,常常發生版本沖突。修復以上問題消耗大量時間,還經常導致其他項目出現問題。必須找到避免這類問題的解決方式,為編寫代碼提供便利。

在本篇文章中我將詳細介紹常用的工具與技巧,希望能為讀者提供幫助。

[[281788]]

Python開發環境

1. 解釋器

從使用Python時最重要的解釋器開始。你當然可以只下載最喜歡的Python版本,然后把所有內容放在里面。但如果你的程序需要不同版本的Python,或依賴于同一第三方模塊的不同版本,并需要在幾個程序之間無縫切換時該怎么辦?

Pyenv可以解決上述問題。

Pyenv共包含三個工具,筆者將介紹其中兩個:pyenv(用于安裝python)和pyenv-virtualenv(用于配置全局工具)。

通過下方網址安裝pyenv。

curl https://pyenv.run | bash

安裝后,向.bashrc(或.zshrc)文件中添加下方代碼,使得pyenv可用于設備。

  1. exportPATH="~/.pyenv/bin:$PATH" 
  2. eval "$(pyenv init -)" 
  3. eval "$(pyenv virtualenv-init -)" 

最后,重啟設備。現在可以使用pyenv安裝幾乎所有的python解釋器,包括pypy、anaconda。

需要注意的是,pyenv只在電腦上搭建本地python環境。搭建python環境需要多種函數庫。在Ubuntu系統的電腦上,必須安裝以下函數庫以防止運行出現問題。

  1. sudo 
  2. apt-get installbuild-essential libsqlite3-dev sqlite3 bzip2 libbz2-dev 
  3. zlib1g-dev libssl-dev openssllibgdbm-dev libgdbm-compat-dev liblzma-dev libreadline-dev libncursesw5-devlibffi-dev uuid-dev 

現在,要安裝python解釋器只需要執行以下指令。

  1. pyenv installVERSION_YOU_WOULD_LIKE_TO_INSTALL 

可以通過pyenv列出所有可用版本。

  1. pyenv install --list 

為了使上述過程更加具體,在此安裝python3.7.5并且設置其為默認的全局解釋器。

  1. pyenv install 3.7.5 
  2. pyenv global 3.7.5 

輸入Python-version指令,屏幕將顯示Python3.7.5。

2. 依賴性關系管理(DependencyManagement)

Python中的依賴性管理是項繁重的工作。有許多工具可以幫助完成這項任務。

我最常使用的工具是Poetry。

Poetry可以幫助你簡單地完成如下工作。

  • 管理項目依賴關系
  • 通過虛擬環境將項目分開
  • 輕松構建應用程序與函數庫

筆者推薦通過以下方式安裝poetry:

  1. curl -sSL https://raw.githubusercontent.com/sdispater/poetry/master/get-poetry.py | python 

另外一種依賴性管理的方式是使用pip和pyenv-virtualenv指令。讀者可能會問:為什么不只用pip?因為只用pip可能會在全局環境中安裝poetry及其依賴項,這可能是你不需要也不想要的。必要指令如下。

  1. # Create a virtual environmentcalled tools that is based on 3.7.5 
  2. pyenv virtualenv 3.7.5 tools 
  3. # Install poetry into the tools virtual env 
  4. pyenv activate tools 
  5. pip install poetry 
  6. # Check installed poetry version 
  7. poetry --version 
  8. # Leave the virtual env 
  9. pyenv deactivate 
  10. # This does not work yet 
  11. poetry --version 
  12. # Add your tools virtual env to the globally available ones 
  13. pyenv global 3.7.5 tools 
  14. # Now this works and you can start using poetry 
  15. poetry --version 

在使用poetry創建第一個項目之前,建議先對其進行配置,這樣就可以在項目目錄中的.venv文件夾中創建虛擬環境。當你使用VsCode或Pycharm這類集成開發環境時就會變得非常方便,因為它們可以立即識別并選擇正確的解釋器。

  1. poetry configsettings.virtualenvs.in-project true 

注意,你只需設置一次配置,設置結果將在全局環境保留。

終于完成了使用poetry創建項目的所有準備工作,太棒了!我把這個項目命名為dsexample,我知道這個名字很蠢,但我不想浪費時間去想一個更好的。為了展示如何使用poetry,我添加了一個特定版本的pandas庫,以及所有額外需求的fastapi框架。

  1. # Initialze a new project 
  2. poetry new dsexample 
  3. cd dsexample 
  4. # Add modules and create virtual environment. 
  5. poetry add pandas=0.25 fastapi --extras all 
  6. # As an example of how you could add a git module 
  7. poetry add tf2-utils --git git@github.com:Shawe82/tf2-utils.git 

如果想要查看一個使用了文中推薦工具的實際項目,請前往我的Github倉庫。

3. 格式一致性與可讀性(Consistent Formatting and Readability)

現在,已經創建好了項目,即將開始添加代碼。理想情況下,代碼庫的格式應該一致,以確保可讀性和可理解性。這將是一個非常沉悶乏味的過程,尤其在還有其他人操作代碼庫時。

但用Black可以解決上述問題!

Black是一種讓程序員在編寫python代碼時能將精力集中于核心內容的工具。它自動為代碼添加格式,避免程序員手動添加格式。因為Black的效果非常好,我們把它添加到dsexample中,讓它為所有的文件添加格式。

  1. # We add black as a developmentdependency with --dev as we don't 
  2. # need it when it comes to production 
  3. poetry add --dev black=19.3b0 
  4. # Assume we are inside the current toplevel dsexample folder 
  5. poetry run black . 

很好,現在所有的文件看起來非常整齊了。

4. 類型糾正(Type-Correctness)

自Python3.5開始(如果我記錯了請糾正),類型注釋開始成為標準庫的一部分通過類型注釋,代碼更好理解,更易維護,不易出錯。為什么會不易出錯呢?因為可以靜態地檢查變量和函數的類型是否符合預期。當然,必須是自動完成的。

下面介紹mypy。

Mypy是一種靜態python代碼檢查器,作用是在錯誤發生之前找到他們。使用poetry向項目中添加mypy并進行代碼檢查與添加black一樣簡單。

  1. # We add mypy as a developmentdependency with --dev as we don't 
  2. # need it when it comes to production 
  3. poetry add --dev mypy 
  4. # Assume we are inside the current toplevel dsexample folder 
  5. poetry run mypy . 

運行mypy也可能導致很多麻煩。當然,可以將其設置為只對你關心的錯誤發出警告。這可以通過在項目中添加mypy.ini文件實現。

5. 將自動化工具自動化(Automate the Automation)

使用black和mypy,我們不再需要手工為代碼添加格式,并且可以避免不必要的錯誤。但是我們仍需要手動使用這兩個工具,這兩個工具不是應該也自動化嗎?

是的!

Pre-commit可以完成一切。

Pre-commit工具是在代碼提交到倉庫前執行檢查(我默認讀者的代碼處在git的控制下)。無法通過檢查的代碼將被拒絕。這樣代碼倉庫就永遠不會出現格式不整齊或是未經類型檢查的代碼,以及任何其他你需要檢查錯誤的代碼。

現在來安裝pre-commit。

可以使用poetry將其直接安裝在項目里,也可以安裝在本地機器里。筆者傾向于后者,因為precommit只在本地使用,而不在CI/CD服務器上。相反,black和mypy在CI/CD服務器上運行,因此,將它們添加到項目的dev依賴項是有意義的。筆者建議使用下面方法通過現有的工具虛擬環境安裝它

  1. # Install pre-commit into the tools virtual env 
  2. pyenv activate tools 
  3. pip install pre-commit 
  4. # Leave the virtual env 
  5. pyenv deactivate 
  6. # As we have already added the tool venv, it will work directly 
  7. pre-commit --version 

要使用pre-commit,首先需要向頂級文件夾中添加一個名為.pre-commit-config.yarm的文件。在該文件里,你需要配置所有應該運行的鉤子。在mypy與Black的環境下,文件內容如下所示。

  1. repos:-   repo: https://github.com/ambv/black    rev: 19.3b0    hooks:    - id: black      language_version: python3.7-   repo: https://github.com/pre-commit/mirrors-mypy    rev: v0.740    hooks:    - id: mypy 

最后,你必須執行以下命令以設置鉤子。

  1. # I assume your are in the toplevel folder 
  2. pre-commit install 

現在,鉤子函數(hook)將在每次提交時運行。Black工具的鉤子函數不僅會檢查格式,還會相應地為文件添加格式。每次添加新的鉤子函數時,建議一開始在所有文件中手動運行pre-commit,因為它只能作用于上次提交之后更改過的文件。

  1. pre-commit run --all-files 

就這樣,對自動化工具的自動化完成了。

總結

有很多工具可以幫助你專注于重要的事情。此處筆者只介紹了其中的幾個。當然,還有更多。希望你學到了新的東西后,可以更加專注于代碼本身。

責任編輯:趙寧寧 來源: 讀芯術
相關推薦

2021-10-14 06:52:47

自動化開發環境

2013-05-02 13:02:59

開發環境自動化團隊

2011-06-22 15:47:16

2020-04-22 17:09:04

Python自動化開發

2019-06-04 08:54:56

Python數據驅動腳本

2024-08-02 17:23:12

2024-03-12 10:02:31

Python內存編程

2018-02-10 18:35:09

LinuxAnsible系統管理

2021-11-29 18:11:33

自動化現代化網絡優化

2022-07-18 08:08:16

Go?語言技巧

2024-02-27 11:17:38

前端自動化測試開發

2023-11-28 10:17:37

2020-07-24 09:52:55

自動化ITCIO

2020-02-27 10:11:11

自動化IT安全

2023-11-20 22:07:51

PythonPDF

2010-12-06 10:10:54

2016-11-07 08:40:51

天池腳本自動化

2022-04-21 16:19:25

云安全多云網絡安全

2018-01-30 17:35:39

LinuxPythonNmon分析器

2020-03-18 09:23:24

Python數據SQL
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 天堂中文av | 精品久久久久久久久久久久久 | 国产高清在线 | 久久网亚洲 | 超碰最新在线 | 亚洲精品成人 | 91久久精品一区二区二区 | 久久久久久久97 | 亚洲国产精久久久久久久 | 欧美亚洲高清 | a级大毛片 | 国产精品久久久久久婷婷天堂 | 中文字幕在线第一页 | 男女国产网站 | 亚洲欧美综合精品另类天天更新 | 欧美精品片 | 亚洲综合视频 | 久久不射电影网 | 亚洲 欧美 日韩 在线 | 国产91在线 | 中日 | 亚洲色欧美另类 | 精品国产一区二区三区av片 | 国产精品久久久久久久久久 | 国产小视频在线看 | 久久精品国产亚洲 | 一级黄a | av不卡一区| 久久精品久久久 | 欧美性极品xxxx做受 | 久久久妇女国产精品影视 | 激情视频一区 | 午夜免费福利电影 | 国产精品国产a | 一级片成人 | 久久久久综合 | 另类a v| 亚洲国产成人精品女人久久久 | 国产精品久久久久久久久免费樱桃 | 亚洲电影专区 | a级毛片毛片免费观看久潮喷 | 亚洲精品一区二区在线 |