編寫高品質程式碼 改善Python程式的91個建議
- 2019 年 12 月 25 日
- 筆記
建議1:理解Pythonic概念
建議2:編寫Pythonic程式碼
建議3:理解Python與C語言的不同之處
建議4:在程式碼中適當添加註釋
建議5:通過適當添加空行使程式碼布局更為優雅、合理
建議6:編寫函數的4個原則
建議7:將常量集中到一個文件
建議8:利用assert語句來發現問題
建議9:數據交換值的時候不推薦使用中間變數
建議10:充分利用Lazy evaluation的特性

建議11:理解枚舉替代實現的缺陷
建議12:不推薦使用type來進行類型檢查
建議13:盡量轉換為浮點類型後再做除法
建議14:警惕eval()的安全漏洞
建議15:使用enumerate()獲取序列迭代的索引和值
建議16:分清=與is的適用場景
建議17:考慮兼容性,儘可能使用Unicode
建議18:構建合理的包層次來管理module
建議19:有節制地使用from…import語句
建議20:優先使用absolute import來導入模組
建議21:i+=1 不等於 ++i
建議22:使用with自動關閉資源
建議23:使用else子句簡化循環(異常處理)
建議24:遵循異常處理的幾點基本原則
建議25:避免finally中可能發生的陷阱
建議26:深人理解None,正確判斷對象是否為空
建議27:連接字元串應優先使用join而不是+
建議28:格式化字元串時盡量使用.format方式而不是%
建議29:區別對待可變對象和不可變對象
建議30:[]、()和{}: 一致的容器初始化形式
建議31:記住函數傳參既不是傳值也不是傳引用
建議32:警惕默認參數潛在的問題
建議33:慎用變長參數
建議34:深入理解str()和repr()的區別
建議35:分清staticmethod和classmethod的適用場景
建議36:掌握字元串的基本用法
建議37:按需選擇sort()或者sorted()
建議38:使用copy模組深拷貝對象
建議39:使用Counter進行計數統計
建議40:深入掌握ConfigParser
建議41:使用argparse處理命令行參數
建議42:使用pandas處理大型CSV文件
建議43:一般情況使用ElementTree解析XML
建議44:理解模組pickle優劣
建議45:序列化的另一個不錯的選擇—JSON
建議46:使用traceback獲取棧資訊
建議47:使用logging記錄日誌資訊
建議48:使用threading模組編寫多執行緒程式
建議49:使用Queue使多執行緒編程更安全
建議50:利用模組實現單例模式
建議51:用mixin模式讓程式更加靈活
建議52:用發布訂閱模式實現松耦合
建議53:用狀態模式美化程式碼
建議54:理解build-in objects
建議55:init() 不是構造方法
建議56:理解名字查找機制
建議57:為什麼需要self參數
建議58:理解MRO與多繼承
建議59:理解描述符機制
建議60:區別getattr()和getattribute()方法
建議61:使用更為安全的property
建議62:掌握metaclass
建議63:熟悉Python對象協議
建議64:利用操作符重載實現中綴語法
建議65:熟悉Python的迭代器協議
建議66:熟悉Python的生成器
建議67:基於生成器的協程及greenlet
建議68:理解GIL的局限性
建議69:對象的管理與垃圾回收
建議70:從PyPI安裝包
建議71:使用pip和yolk安裝、管理包
建議72:做paster創建包
建議73:理解單元測試概念
建議74:為包編寫單元測試
建議75:利用測試驅動開發提高程式碼的可測性
建議76:使用Pylint檢查程式碼風格
建議77:進行高效的程式碼審查
建議78:將包發布到PyPI
建議79:了解程式碼優化的基本原則
建議80:藉助性能優化工具
建議81:利用cProfile定位性能瓶頸
建議82:使用memory_profiler和objgrash剖析記憶體使用
建議83:努力降低演算法複雜度
建議84:掌握循環優化的基本技巧
建議85:使用生成器提高效率
建議86:使用不同的數據結構優化性能
建議87:充分利用set的優勢
建議88:使用meltiprocessing克服GIL的缺陷
建議89:使用執行緒池提高效率
建議90:使用C/C++模組擴展提高性能
建議91:使用Cython編寫擴展模組