90 條寫 Python 程序的建議

自己寫 Python 也有四五年了琳状,一直是用自己的“強(qiáng)迫癥”在維持自己代碼的質(zhì)量。都有去看Google的Python代碼規(guī)范咬像,對(duì)這幾年的工作經(jīng)驗(yàn)算撮,做個(gè)簡(jiǎn)單的筆記,如果你也在學(xué)pythpn县昂,準(zhǔn)備要學(xué)習(xí)python肮柜,希望這篇文章對(duì)你有用。

???1.首先

建議1倒彰、理解Pythonic概念—-詳見Python中的《Python之禪》

建議2审洞、編寫Pythonic代碼

(1)避免不規(guī)范代碼,比如只用大小寫區(qū)分變量待讳、使用容易混淆的變量名芒澜、害怕過長(zhǎng)變量名等。有時(shí)候長(zhǎng)的變量名會(huì)使代碼更加具有可讀性创淡。

(2)深入學(xué)習(xí)Python相關(guān)知識(shí)痴晦,比如語(yǔ)言特性、庫(kù)特性等琳彩,比如Python演變過程等誊酌。深入學(xué)習(xí)一兩個(gè)業(yè)內(nèi)公認(rèn)的Pythonic的代碼庫(kù),比如Flask等露乏。

建議3:理解Python與C的不同之處碧浊,比如縮進(jìn)與{},單引號(hào)雙引號(hào)瘟仿,三元操作符箱锐?,Switch-Case語(yǔ)句等劳较。

建議4:在代碼中適當(dāng)添加注釋

建議5:適當(dāng)添加空行使代碼布局更加合理

建議6:編寫函數(shù)的4個(gè)原則

(1)函數(shù)設(shè)計(jì)要盡量短小驹止,嵌套層次不宜過深

(2)函數(shù)聲明應(yīng)該做到合理浩聋、簡(jiǎn)單、易用

(3)函數(shù)參數(shù)設(shè)計(jì)應(yīng)該考慮向下兼容

(4)一個(gè)函數(shù)只做一件事幢哨,盡量保證函數(shù)粒度的一致性

建議7:將常量集中在一個(gè)文件赡勘,且常量名盡量使用全大寫字母

???2.編程慣用法

建議8:利用assert語(yǔ)句來發(fā)現(xiàn)問題,但要注意捞镰,斷言assert會(huì)影響效率

建議9:數(shù)據(jù)交換值時(shí)不推薦使用臨時(shí)變量闸与,而是直接a, b = b, a

建議10:充分利用惰性計(jì)算(Lazy evaluation)的特性,從而避免不必要的計(jì)算

建議11:理解枚舉替代實(shí)現(xiàn)的缺陷(最新版Python中已經(jīng)加入了枚舉特性)

建議12:不推薦使用type來進(jìn)行類型檢查岸售,因?yàn)橛行r(shí)候type的結(jié)果并不一定可靠践樱。如果有需求,建議使用isinstance函數(shù)來代替

建議13:盡量將變量轉(zhuǎn)化為浮點(diǎn)類型后再做除法(Python3以后不用考慮)

建議14:警惕eval()函數(shù)的安全漏洞凸丸,有點(diǎn)類似于SQL注入

建議15:使用enumerate()同時(shí)獲取序列迭代的索引和值

建議16:分清==和is的適用場(chǎng)景拷邢,特別是在比較字符串等不可變類型變量時(shí)(詳見評(píng)論)

建議17:盡量使用Unicode。在Python2中編碼是很讓人頭痛的一件事屎慢,但Python3就不用過多考慮了

建議18:構(gòu)建合理的包層次來管理Module

???3.基礎(chǔ)用法

建議19:有節(jié)制的使用from…import語(yǔ)句瞭稼,防止污染命名空間

建議20:優(yōu)先使用absolute import來導(dǎo)入模塊(Python3中已經(jīng)移除了relative import)

建議21:i+=1不等于++i,在Python中腻惠,++i前邊的加號(hào)僅表示正环肘,不表示操作

建議22:習(xí)慣使用with自動(dòng)關(guān)閉資源,特別是在文件讀寫中

建議23:使用else子句簡(jiǎn)化循環(huán)(異常處理)

建議24:遵循異常處理的幾點(diǎn)基本原則

(1)注意異常的粒度集灌,try塊中盡量少寫代碼

(2)謹(jǐn)慎使用單獨(dú)的except語(yǔ)句悔雹,或except Exception語(yǔ)句,而是定位到具體異常

(3)注意異常捕獲的順序欣喧,在合適的層次處理異常

(4)使用更加友好的異常信息腌零,遵守異常參數(shù)的規(guī)范

建議25:避免finally中可能發(fā)生的陷阱

建議26:深入理解None,正確判斷對(duì)象是否為空唆阿。

建議27:連接字符串應(yīng)優(yōu)先使用join函數(shù)益涧,而不是+操作

建議28:格式化字符串時(shí)盡量使用.format函數(shù),而不是%形式

建議29:區(qū)別對(duì)待可變對(duì)象和不可變對(duì)象驯鳖,特別是作為函數(shù)參數(shù)時(shí)

建議30:[], {}和():一致的容器初始化形式饰躲。使用列表解析可以使代碼更清晰,同時(shí)效率更高

建議31:函數(shù)傳參數(shù)臼隔,既不是傳值也不是傳引用,而是傳對(duì)象或者說對(duì)象的引用

建議32:警惕默認(rèn)參數(shù)潛在的問題妄壶,特別是當(dāng)默認(rèn)參數(shù)為可變對(duì)象時(shí)

建議33:函數(shù)中慎用變長(zhǎng)參數(shù) args和 kargs

(1)這種使用太靈活摔握,從而使得函數(shù)簽名不夠清晰,可讀性較差

(2)如果因?yàn)楹瘮?shù)參數(shù)過多而是用變長(zhǎng)參數(shù)簡(jiǎn)化函數(shù)定義丁寄,那么一般該函數(shù)可以重構(gòu)

建議34:深入理解str()和repr()的區(qū)別

(1)兩者之間的目標(biāo)不同:str主要面向客戶氨淌,其目的是可讀性泊愧,返回形式為用戶友好性和可讀性都比較高的字符串形式;而repr是面向Python解釋器或者說Python開發(fā)人員盛正,其目的是準(zhǔn)確性删咱,其返回值表示Python解釋器內(nèi)部的定義

(2)在解釋器中直接輸入變量,默認(rèn)調(diào)用repr函數(shù)豪筝,而print(var)默認(rèn)調(diào)用str函數(shù)

(3)repr函數(shù)的返回值一般可以用eval函數(shù)來還原對(duì)象

(4)兩者分別調(diào)用對(duì)象的內(nèi)建函數(shù) __str__ ()和 __repr__ ()

建議35:分清靜態(tài)方法staticmethod和類方法classmethod的使用場(chǎng)景

???4.庫(kù)的使用

建議36:掌握字符串的基本用法

建議37:按需選擇sort()和sorted()函數(shù)

sort()是列表在就地進(jìn)行排序痰滋,所以不能排序元組等不可變類型。

sorted()可以排序任意的可迭代類型续崖,同時(shí)不改變?cè)兞勘旧怼?/p>

建議38:使用copy模塊深拷貝對(duì)象敲街,區(qū)分淺拷貝(shallow copy)和深拷貝(deep copy)

建議39:使用Counter進(jìn)行計(jì)數(shù)統(tǒng)計(jì),Counter是字典類的子類严望,在collections模塊中

建議40:深入掌握ConfigParse

建議41:使用argparse模塊處理命令行參數(shù)

建議42:使用pandas處理大型CSV文件

Python本身提供一個(gè)CSV文件處理模塊多艇,并提供reader、writer等函數(shù)像吻。

Pandas可提供分塊峻黍、合并處理等,適用于數(shù)據(jù)量大的情況拨匆,且對(duì)二維數(shù)據(jù)操作更方便姆涩。

建議43:使用ElementTree解析XML

建議44:理解模塊pickle的優(yōu)劣

優(yōu)勢(shì):接口簡(jiǎn)單、各平臺(tái)通用涮雷、支持的數(shù)據(jù)類型廣泛阵面、擴(kuò)展性強(qiáng)

劣勢(shì):不保證數(shù)據(jù)操作的原子性、存在安全問題洪鸭、不同語(yǔ)言之間不兼容

建議45:序列化的另一個(gè)選擇JSON模塊:load和dump操作

建議46:使用traceback獲取棧信息

建議47:使用logging記錄日志信息

建議48:使用threading模塊編寫多線程程序

建議49:使用Queue模塊使多線程編程更安全

??5.設(shè)計(jì)模式

建議50:利用模塊實(shí)現(xiàn)單例模式

建議51:用mixin模式讓程序更加靈活

建議52:用發(fā)布-訂閱模式實(shí)現(xiàn)松耦合

建議53:用狀態(tài)模式美化代碼

??6.內(nèi)部機(jī)制

建議54:理解build-in對(duì)象

建議55:__init__ ()不是構(gòu)造方法样刷,理解 __new__ ()與它之間的區(qū)別

建議56:理解變量的查找機(jī)制,即作用域

局部作用域

全局作用域

嵌套作用域

內(nèi)置作用域

建議57:為什么需要self參數(shù)

建議58:理解MRO(方法解析順序)與多繼承

建議59:理解描述符機(jī)制

建議60:區(qū)別 __getattr__ ()與 __getattribute__ ()方法之間的區(qū)別

建議61:使用更安全的property

建議62:掌握元類metaclass

建議63:熟悉Python對(duì)象協(xié)議

建議64:利用操作符重載實(shí)現(xiàn)中綴語(yǔ)法

建議65:熟悉Python的迭代器協(xié)議

建議66:熟悉Python的生成器

建議67:基于生成器的協(xié)程和greenlet览爵,理解協(xié)程置鼻、多線程、多進(jìn)程之間的區(qū)別

建議68:理解GIL的局限性

建議69:對(duì)象的管理和垃圾回收

??7.使用工具輔助項(xiàng)目開發(fā)

建議70:從PyPI安裝第三方包

建議71:使用pip和yolk安裝蜓竹、管理包

建議72:做paster創(chuàng)建包

建議73:理解單元測(cè)試的概念

建議74:為包編寫單元測(cè)試

建議75:利用測(cè)試驅(qū)動(dòng)開發(fā)(TDD)提高代碼的可測(cè)性

建議76:使用Pylint檢查代碼風(fēng)格

代碼風(fēng)格審查

代碼錯(cuò)誤檢查

發(fā)現(xiàn)重復(fù)以及不合理的代碼箕母,方便重構(gòu)

高度的可配置化和可定制化

支持各種IDE和編輯器的集成

能夠基于Python代碼生成UML圖

能夠與Jenkins等持續(xù)集成工具相結(jié)合,支持自動(dòng)代碼審查

建議77:進(jìn)行高效的代碼審查

建議78:將包發(fā)布到PyPI

??8.性能剖析與優(yōu)化

建議79:了解代碼優(yōu)化的基本原則

建議80:借助性能優(yōu)化工具

建議81:利用cProfile定位性能瓶頸

建議82:使用memory_profiler和objgraph剖析內(nèi)存使用

建議83:努力降低算法復(fù)雜度

建議84:掌握循環(huán)優(yōu)化的基本技巧

減少循環(huán)內(nèi)部的計(jì)算

將顯式循環(huán)改為隱式循環(huán)俱济,當(dāng)然這會(huì)犧牲代碼的可讀性

在循環(huán)中盡量引用局部變量

關(guān)注內(nèi)層嵌套循環(huán)

建議85:使用生成器提高效率

建議86:使用不同的數(shù)據(jù)結(jié)構(gòu)優(yōu)化性能

建議87:充分利用set的優(yōu)勢(shì)

建議88:使用multiprocessing模塊克服GIL缺陷

建議89:使用線程池提高效率

建議90:使用Cythonb編寫擴(kuò)展模塊

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末嘶是,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蛛碌,更是在濱河造成了極大的恐慌聂喇,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異希太,居然都是意外死亡克饶,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門誊辉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來矾湃,“玉大人,你說我怎么就攤上這事堕澄⊙荆” “怎么了?”我有些...
    開封第一講書人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵奈偏,是天一觀的道長(zhǎng)坞嘀。 經(jīng)常有香客問我,道長(zhǎng)惊来,這世上最難降的妖魔是什么丽涩? 我笑而不...
    開封第一講書人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮裁蚁,結(jié)果婚禮上矢渊,老公的妹妹穿的比我還像新娘。我一直安慰自己枉证,他們只是感情好矮男,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著室谚,像睡著了一般毡鉴。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上秒赤,一...
    開封第一講書人閱讀 51,292評(píng)論 1 301
  • 那天猪瞬,我揣著相機(jī)與錄音,去河邊找鬼入篮。 笑死陈瘦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的潮售。 我是一名探鬼主播痊项,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼酥诽!你這毒婦竟也來了鞍泉?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤肮帐,失蹤者是張志新(化名)和其女友劉穎咖驮,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡游沿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了肮砾。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诀黍。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖仗处,靈堂內(nèi)的尸體忽然破棺而出眯勾,到底是詐尸還是另有隱情,我是刑警寧澤婆誓,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布吃环,位于F島的核電站,受9級(jí)特大地震影響洋幻,放射性物質(zhì)發(fā)生泄漏郁轻。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一文留、第九天 我趴在偏房一處隱蔽的房頂上張望好唯。 院中可真熱鬧,春花似錦燥翅、人聲如沸骑篙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)靶端。三九已至,卻和暖如春凛膏,著一層夾襖步出監(jiān)牢的瞬間杨名,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工译柏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留镣煮,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓鄙麦,卻偏偏與公主長(zhǎng)得像典唇,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子胯府,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354