Python 軟件開發(fā)目錄規(guī)范的重要性
為什么要設(shè)計好目錄結(jié)構(gòu)?
"設(shè)計項目目錄結(jié)構(gòu)",就和"代碼編碼風(fēng)格"一樣,屬于個人風(fēng)格問題。對于這種風(fēng)格上的規(guī)范,一直都存在兩種態(tài)度:
一類同學(xué)認(rèn)為,這種個人風(fēng)格問題"無關(guān)緊要"。理由是能讓程序work就好,風(fēng)格問題根本不是問題。
另一類同學(xué)認(rèn)為,規(guī)范化能更好的控制程序結(jié)構(gòu),讓程序具有更高的可讀性。
我是比較偏向于后者的,因為我是前一類同學(xué)思想行為下的直接受害者。我曾經(jīng)維護(hù)過一個非常不好讀的項目,其實現(xiàn)的邏輯并不復(fù)雜,但是卻耗費(fèi)了我非常長的時間去理解它想表達(dá)的意思。從此我個人對于提高項目可讀性、可維護(hù)性的要求就很高了。"項目目錄結(jié)構(gòu)"其實也是屬于"可讀性和可維護(hù)性"的范疇,我們設(shè)計一個層次清晰的目錄結(jié)構(gòu),就是為了達(dá)到以下兩點:
可讀性高:不熟悉這個項目的代碼的人,一眼就能看懂目錄結(jié)構(gòu),知道程序啟動腳本是哪個,測試目錄在哪兒,配置文件在哪兒等等。從而非常快速的了解這個項目。
可維護(hù)性高:定義好組織規(guī)則后,維護(hù)者就能很明確地知道,新增的哪個文件和代碼應(yīng)該放在什么目錄之下。這個好處是,隨著時間的推移,代碼/配置的規(guī)模增加,項目結(jié)構(gòu)不會混亂,仍然能夠組織良好。
所以,我認(rèn)為,保持一個層次清晰的目錄結(jié)構(gòu)是有必要的。更何況組織一個良好的工程目錄,其實是一件很簡單的事兒。
目錄組織方式
關(guān)于如何組織一個較好的Python工程目錄結(jié)構(gòu),已經(jīng)有一些得到了共識的目錄結(jié)構(gòu)。在Stackoverflow的這個問題上,能看到大家對Python目錄結(jié)構(gòu)的討論。
這里面說的已經(jīng)很好了,我也不打算重新造輪子列舉各種不同的方式,這里面我說一下我的理解和體會。
假設(shè)你的項目名為foo,我比較建議的最方便快捷目錄結(jié)構(gòu)這樣就足夠了
簡要解釋一下:
bin/:存放項目的一些可執(zhí)行文件,當(dāng)然你可以起名script/之類的也行。
foo/:存放項目的所有源代碼。(1)源代碼中的所有模塊、包都應(yīng)該放在此目錄。不要置于頂層目錄。(2)其子目錄tests/存放單元測試代碼;(3)程序的入口最好命名為main.py。
docs/:存放一些文檔。
setup.py:安裝、部署、打包的腳本。
requirements.txt:存放軟件依賴的外部Python包列表。
README:項目說明文件。
除此之外,有一些方案給出了更加多的內(nèi)容。比如LICENSE.txt,ChangeLog.txt文件等,我沒有列在這里,因為這些東西主要是項目開源的時候需要用到。如果你想寫一個開源軟件,目錄該如何組織
以上內(nèi)容為大家介紹了Python軟件開發(fā)目錄規(guī)范的重要性,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。

猜你喜歡LIKE
相關(guān)推薦HOT
更多>>
如何使用Pandas處理Excel?
如何使用Pandas處理Excel?做過行政或者人事,或者對此有過了解的小伙伴,一定對下發(fā)各個部分的表有著非常深刻的印象,最常見的就是需要我們將一...詳情>>
2023-11-14 07:43:15
python中np.insert()函數(shù)的使用方法
python中np.insert()函數(shù)的使用方法在numpy數(shù)組操作中,np.append()方法可以在每行每列的最后添加數(shù)據(jù),但其位置是規(guī)定的,那如果想要指定添加...詳情>>
2023-11-14 05:06:13
SVM在python中的原理如何理解?
SVM在python中的原理如何理解?在python中除了編程化的知識點外,對于數(shù)學(xué)方法的算法也有所涉及,SVM就是一種很好地體現(xiàn)。我們學(xué)習(xí)過數(shù)學(xué)中的坐...詳情>>
2023-11-14 04:30:04
python處理絕對路徑和相對路徑函數(shù)有哪些?
python處理絕對路徑和相對路徑函數(shù)有哪些?絕對路徑和相對路徑是什么?絕對路徑:從根文件夾開始,Windows系統(tǒng)以盤符(C:)作為根文件夾,OSX或Lin...詳情>>
2023-11-14 03:33:02熱門推薦
如何使用python any()判斷多元素?
沸如何使用Pandas處理Excel?
熱python函數(shù)中的參數(shù)有哪些?
熱python中pygal模塊如何使用?
新Python的excel處理操作
python中doctest庫是什么?
python中series是什么意思
python中np.insert()函數(shù)的使用方法
SVM在python中的原理如何理解?
Python描述符中有哪三種方法?
python處理絕對路徑和相對路徑函數(shù)有哪些?
python單繼承和多繼承如何定義?
python封裝中的私有如何理解?
python模塊引入的三種方式
技術(shù)干貨







快速通道 更多>>
-
課程介紹
點擊獲取大綱 -
就業(yè)前景
查看就業(yè)薪資 -
學(xué)習(xí)費(fèi)用
了解課程價格 -
優(yōu)惠活動
領(lǐng)取優(yōu)惠券 -
學(xué)習(xí)資源
領(lǐng)3000G教程 -
師資團(tuán)隊
了解師資團(tuán)隊 -
實戰(zhàn)項目
獲取項目源碼 -
開班地區(qū)
查看來校路線