讓Python代碼更易維護(hù)的幾種優(yōu)質(zhì)工具

隨著軟件項(xiàng)目進(jìn)入“維護(hù)模式”固阁,對(duì)可讀性和編碼標(biāo)準(zhǔn)的要求很容易落空(甚至從一開(kāi)始就沒(méi)有建立過(guò)那些標(biāo)準(zhǔn))冲粤。然而,在代碼庫(kù)中保持一致的代碼風(fēng)格和測(cè)試標(biāo)準(zhǔn)能夠顯著減輕維護(hù)的壓力桐愉,也能確保新的開(kāi)發(fā)者能夠快速了解項(xiàng)目的情況危纫,同時(shí)能更好地全程保持應(yīng)用程序的質(zhì)量宗挥。

使用外部庫(kù)來(lái)檢查代碼的質(zhì)量不失為保護(hù)項(xiàng)目未來(lái)可維護(hù)性的一個(gè)好方法。以下會(huì)推薦一些我們最喜愛(ài)的檢查代碼(包括檢查 PEP 8 和其它代碼風(fēng)格錯(cuò)誤)的庫(kù)种蝶,用它們來(lái)強(qiáng)制保持代碼風(fēng)格一致契耿,并確保在項(xiàng)目成熟時(shí)有一個(gè)可接受的測(cè)試覆蓋率。

檢查你的代碼風(fēng)格

PEP 8 是 Python 代碼風(fēng)格規(guī)范螃征,它規(guī)定了類(lèi)似行長(zhǎng)度搪桂、縮進(jìn)、多行表達(dá)式盯滚、變量命名約定等內(nèi)容踢械。盡管你的團(tuán)隊(duì)自身可能也會(huì)有稍微不同于 PEP 8 的代碼風(fēng)格規(guī)范,但任何代碼風(fēng)格規(guī)范的目標(biāo)都是在代碼庫(kù)中強(qiáng)制實(shí)施一致的標(biāo)準(zhǔn)淌山,使代碼的可讀性更強(qiáng)裸燎、更易于維護(hù)顾瞻。下面三個(gè)庫(kù)就可以用來(lái)幫助你美化代碼泼疑。

1、 Pylint

Pylint 是一個(gè)檢查違反 PEP 8 規(guī)范和常見(jiàn)錯(cuò)誤的庫(kù)荷荤。它在一些流行的編輯器和 IDE 中都有集成退渗,也可以單獨(dú)從命令行運(yùn)行。

執(zhí)行 pip install pylint 安裝 Pylint 蕴纳。然后運(yùn)行 pylint [options] path/to/dir 或者 pylint [options] path/to/module.py 就可以在命令行中使用 Pylint会油,它會(huì)向控制臺(tái)輸出代碼中違反規(guī)范和出現(xiàn)錯(cuò)誤的地方。

你還可以使用 pylintrc 配置文件來(lái)自定義 Pylint 對(duì)哪些代碼錯(cuò)誤進(jìn)行檢查古毛。

2翻翩、 Flake8

Flake8 是“將 PEP 8、Pyflakes(類(lèi)似 Pylint)稻薇、McCabe(代碼復(fù)雜性檢查器)和第三方插件整合到一起嫂冻,以檢查 Python 代碼風(fēng)格和質(zhì)量的一個(gè) Python 工具”。

執(zhí)行 pip install flake8 安裝 flake8 塞椎,然后執(zhí)行 flake8 [options] path/to/dir 或者 flake8 [options] path/to/module.py 可以查看報(bào)出的錯(cuò)誤和警告桨仿。

和 Pylint 類(lèi)似,F(xiàn)lake8 允許通過(guò)配置文件來(lái)自定義檢查的內(nèi)容案狠。它有非常清晰的文檔服傍,包括一些有用的提交鉤子钱雷,可以將自動(dòng)檢查代碼納入到開(kāi)發(fā)工作流程之中。

Flake8 也可以集成到一些流行的編輯器和 IDE 當(dāng)中吹零,但在文檔中并沒(méi)有詳細(xì)說(shuō)明罩抗。要將 Flake8 集成到喜歡的編輯器或 IDE 中,可以搜索插件(例如 Sublime Text 的 Flake8 插件)灿椅。

3澄暮、 Isort

Isort 這個(gè)庫(kù)能將你在項(xiàng)目中導(dǎo)入的庫(kù)按字母順序排序,并將其正確劃分為不同部分(例如標(biāo)準(zhǔn)庫(kù)阱扬、第三方庫(kù)泣懊、自建的庫(kù)等)。這樣提高了代碼的可讀性麻惶,并且可以在導(dǎo)入的庫(kù)較多的時(shí)候輕松找到各個(gè)庫(kù)馍刮。

執(zhí)行 pip install isort 安裝 isort,然后執(zhí)行 isort path/to/module.py 就可以運(yùn)行了窃蹋。文檔中還提供了更多的配置項(xiàng)卡啰,例如通過(guò)配置 .isort.cfg 文件來(lái)決定 isort 如何處理一個(gè)庫(kù)的多行導(dǎo)入。

和 Flake8警没、Pylint 一樣匈辱,isort 也提供了將其與流行的編輯器和 IDE 集成的插件。

分享你的代碼風(fēng)格

每次文件發(fā)生變動(dòng)之后都用命令行手動(dòng)檢查代碼是一件痛苦的事杀迹,你可能也不太喜歡通過(guò)運(yùn)行 IDE 中某個(gè)插件來(lái)實(shí)現(xiàn)這個(gè)功能亡脸。同樣地,你的同事可能會(huì)用不同的代碼檢查方式树酪,也許他們的編輯器中也沒(méi)有那種插件浅碾,甚至你自己可能也不會(huì)嚴(yán)格檢查代碼和按照警告來(lái)更正代碼⌒铮總之垂谢,你分享出來(lái)的代碼庫(kù)將會(huì)逐漸地變得混亂且難以閱讀。

一個(gè)很好的解決方案是使用一個(gè)庫(kù)疮茄,自動(dòng)將代碼按照 PEP 8 規(guī)范進(jìn)行格式化滥朱。我們推薦的三個(gè)庫(kù)都有不同的自定義級(jí)別來(lái)控制如何格式化代碼。其中有一些設(shè)置較為特殊力试,例如 Pylint 和 Flake8 徙邻,你需要先行測(cè)試,看看是否有你無(wú)法忍受但又不能修改的默認(rèn)配置懂版。

4鹃栽、 Autopep8

Autopep8 可以自動(dòng)格式化指定的模塊中的代碼,包括重新縮進(jìn)行、修復(fù)縮進(jìn)民鼓、刪除多余的空格薇芝,并重構(gòu)常見(jiàn)的比較錯(cuò)誤(例如布爾值和 None 值)。你可以查看文檔中完整的更正列表丰嘉。

運(yùn)行 pip install --upgrade autopep8 安裝 Autopep8夯到。然后執(zhí)行 autopep8 --in-place --aggressive --aggressive 就可以重新格式化你的代碼。aggressive 選項(xiàng)的數(shù)量表示 Auotopep8 在代碼風(fēng)格控制上有多少控制權(quán)饮亏。在這里可以詳細(xì)了解 aggressive 選項(xiàng)耍贾。

5、 Yapf

Yapf 是另一種有自己的配置項(xiàng)列表的重新格式化代碼的工具路幸。它與 Autopep8 的不同之處在于它不僅會(huì)指出代碼中違反 PEP 8 規(guī)范的地方荐开,還會(huì)對(duì)沒(méi)有違反 PEP 8 但代碼風(fēng)格不一致的地方重新格式化,旨在令代碼的可讀性更強(qiáng)简肴。

執(zhí)行 pip install yapf 安裝 Yapf晃听,然后執(zhí)行 yapf [options] path/to/dir 或 yapf [options] path/to/module.py 可以對(duì)代碼重新格式化。定制選項(xiàng)的完整列表在這里砰识。

6能扒、 Black

Black 在代碼檢查工具當(dāng)中算是比較新的一個(gè)。它與 Autopep8 和 Yapf 類(lèi)似辫狼,但限制較多初斑,沒(méi)有太多的自定義選項(xiàng)。這樣的好處是你不需要去決定使用怎么樣的代碼風(fēng)格膨处,讓 Black 來(lái)給你做決定就好见秤。你可以在這里查閱 Black 有限的自定義選項(xiàng)以及如何在配置文件中對(duì)其進(jìn)行設(shè)置。

Black 依賴(lài)于 Python 3.6+灵迫,但它可以格式化用 Python 2 編寫(xiě)的代碼秦叛。執(zhí)行 pip install black 安裝 Black晦溪,然后執(zhí)行 black path/to/dir 或 black path/to/module.py 就可以使用 Black 優(yōu)化你的代碼瀑粥。

檢查你的測(cè)試覆蓋率

如果你正在進(jìn)行編寫(xiě)測(cè)試,你需要確保提交到代碼庫(kù)的新代碼都已經(jīng)測(cè)試通過(guò)三圆,并且不會(huì)降低測(cè)試覆蓋率狞换。雖然測(cè)試覆蓋率不是衡量測(cè)試有效性和充分性的唯一指標(biāo),但它是確保項(xiàng)目遵循基本測(cè)試標(biāo)準(zhǔn)的一種方法舟肉。對(duì)于計(jì)算測(cè)試覆蓋率修噪,我們推薦使用 Coverage 這個(gè)庫(kù)。

7路媚、 Coverage

Coverage 有數(shù)種顯示測(cè)試覆蓋率的方式黄琼,包括將結(jié)果輸出到控制臺(tái)或 HTML 頁(yè)面,并指出哪些具體哪些地方?jīng)]有被覆蓋到整慎。你可以通過(guò)配置文件自定義 Coverage 檢查的內(nèi)容脏款,讓你更方便使用围苫。

執(zhí)行 pip install coverage 安裝 Converage 。然后執(zhí)行 coverage [path/to/module.py] [args] 可以運(yùn)行程序并查看輸出結(jié)果撤师。如果要查看哪些代碼行沒(méi)有被覆蓋剂府,執(zhí)行 coverage report -m 即可。

持續(xù)集成工具

持續(xù)集成Continuous integration(CI)是在合并和部署代碼之前自動(dòng)檢查代碼風(fēng)格錯(cuò)誤和測(cè)試覆蓋率最小值的過(guò)程剃盾。很多免費(fèi)或付費(fèi)的工具都可以用于執(zhí)行這項(xiàng)工作腺占,具體的過(guò)程不在本文中贅述,但 CI 過(guò)程是令代碼更易讀和更易維護(hù)的重要步驟痒谴,關(guān)于這一部分可以參考 Travis CI 和 Jenkins衰伯。

文章來(lái)自http://www.childscode.com趣兒少兒編程

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末积蔚,一起剝皮案震驚了整個(gè)濱河市嚎研,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌库倘,老刑警劉巖临扮,帶你破解...
    沈念sama閱讀 221,430評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異教翩,居然都是意外死亡杆勇,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門(mén)饱亿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蚜退,“玉大人,你說(shuō)我怎么就攤上這事彪笼∽曜ⅲ” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 167,834評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵配猫,是天一觀(guān)的道長(zhǎng)幅恋。 經(jīng)常有香客問(wèn)我,道長(zhǎng)泵肄,這世上最難降的妖魔是什么捆交? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,543評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮腐巢,結(jié)果婚禮上品追,老公的妹妹穿的比我還像新娘。我一直安慰自己冯丙,他們只是感情好肉瓦,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,547評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般泞莉。 火紅的嫁衣襯著肌膚如雪洁墙。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,196評(píng)論 1 308
  • 那天戒财,我揣著相機(jī)與錄音热监,去河邊找鬼。 笑死饮寞,一個(gè)胖子當(dāng)著我的面吹牛孝扛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播幽崩,決...
    沈念sama閱讀 40,776評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼苦始,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了慌申?” 一聲冷哼從身側(cè)響起陌选,我...
    開(kāi)封第一講書(shū)人閱讀 39,671評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蹄溉,沒(méi)想到半個(gè)月后咨油,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,221評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡柒爵,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,303評(píng)論 3 340
  • 正文 我和宋清朗相戀三年役电,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片棉胀。...
    茶點(diǎn)故事閱讀 40,444評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡法瑟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出唁奢,到底是詐尸還是另有隱情霎挟,我是刑警寧澤,帶...
    沈念sama閱讀 36,134評(píng)論 5 350
  • 正文 年R本政府宣布麻掸,位于F島的核電站酥夭,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏论笔。R本人自食惡果不足惜采郎,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,810評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望狂魔。 院中可真熱鬧,春花似錦淫痰、人聲如沸最楷。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,285評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)籽孙。三九已至烈评,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間犯建,已是汗流浹背讲冠。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,399評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留适瓦,地道東北人竿开。 一個(gè)月前我還...
    沈念sama閱讀 48,837評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像玻熙,于是被迫代替她去往敵國(guó)和親否彩。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,455評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容