python:軟件目錄結構規范

為什么要設計好目錄結構?

“設計項目目錄結構”,就和“代碼編碼風格”一樣,屬于個人風格問題。對于這種風格上的規范,一直都存在兩種態度:

  1.一種認為,這種個人風格問題“無關緊要”。理由是能讓程序work就好,風格問題根本不是問題。

  2.另一種認為,規范化能更好地控制程序結構,讓程序具有更高的可讀性。

個人傾向于后者。“項目目錄結構”其實也是屬于“可讀性和可維護性”的范疇,我們設計一個層次清晰的目錄結構,就是為了達到以下兩點:

  1.可讀性高:不熟悉這個項目的代碼的人,一眼就能看懂目錄結構,知道程序啟動腳本是哪個,測試目錄在哪兒,配置文件在哪兒等等。從而非常快速的了解這個項目。

  2.可維護性高:定義好組織規則后,維護者就能很明確地知道,新增的哪個文件和代碼應該放在什么目錄之下。這個好處是,隨著時間的推移,代碼/配置的規模增加,項目結構不會混亂,仍然能夠組織良好

故而,保持一個層次清晰的目錄結構是有必要的。更何況組織一個良好的工程目錄,其實是一件很簡單的事兒。

?

目錄組織方式:

關于如何組織好一個較好的python工程目錄結構,已經有一些得到了共識額目錄結構。在Stackoverflow這個問題上,能看到大家對python目錄結構的討論.

如:假設你的項目名為foo,個人建議的最方便快捷目錄結構這樣就足夠了

Foo/
|-- bin/
| |-- foo
|
|-- foo/
| |-- tests/
| | |-- __init__.py
| | |-- test_main.py
| |
| |-- __init__.py
| |-- main.py
|
| |-- conf.py
| |-- abc.rst
|
|-- setup.py
|-- requirements.txt
|-- README
簡單解釋一下:
1.bin/:存放項目的一些可執行文件,當然你可以起名script/之類的也行。
2.foo/:存放項目的所有源代碼。(1)源代碼中的的所有模塊、包都應該放在此目錄。不要置于頂層目錄。(2)其子目錄tests/存放單元測試代碼;
(3)程序的入口最好命名為main.py
3.docs/:存放一些文檔。
4.setup.py:安裝、部署、打包的腳本。
5.requirements.txt:存放軟件依賴的外部python包列表。
6.README:項目說明文件
除此之外,有一些方案給出了更加多的內容。比如LIENSE.txt,ChangeLog.txt文件等(這里沒有列出,是因為這些東西在項目開源時才用得到)

關于README的內容
這個文件,個人覺得是每個項目都該有的一個文件,目的是能簡要描述項目的信息,讓讀者快速了解這個項目。
它主要說明以下幾個事項:
1.軟件定位,軟件的基本功能。
2.運行代碼的方法:安裝環境、啟動命令等。
3.簡要的使用說明。
4.代碼目錄結構說明,更詳細點可以說明軟件的基本原理。
5.常見問題說明。

?

轉載于:https://www.cnblogs.com/cansun/p/8120281.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/281541.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/281541.shtml
英文地址,請注明出處:http://en.pswp.cn/news/281541.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

開啟智能生活新時代 河北省智慧社區建設從各個擊破

智慧社區作為智慧城市的重要組成部分,是城市智慧落地的觸點,是城市管理、政務服務和市場服務的載體。隨著智慧城市的推廣以及新一代技術的普及,智慧社區的項目必將迎來新一輪的快速發展。2016年智慧社區成為企業業務落地的承載點,…

C# WPF 表格控件的前后臺數據交互?

概述GridControl控件使用我們已經進行了實例講解,這節內容我們列舉一個特殊的應用場景:表格中有一列CheckBox,默認都處于勾選狀態,當用戶通過界面操作后,我們要確保用戶至少選擇了一項,相當于一次數據驗證&…

Java(C#)基礎差異-語法

1、long類型 Java long類型,若賦值大于int型的最大值,或小于int型的最小值,則需要在數字后加L或者l,表示該數值為長整數,如long num2147483650L。 舉例如下: public static void main(String[] args) {/** …

android防止左向右滑出程序,Android——ViewPager禁止左右滑動的實現

目錄1 背景用ViewPagerBottomNavigationView多個Fragment快速搭建的頁面切換架構,一個有四個頁面,因為測試需要,需要屏蔽掉中間的兩個,做法是:設置不可點擊選擇:xml布局文件中,BottomNavigation…

Yii2 的快速配置 api 服務 yii2-fast-api

yii2-fast-api yii2-fast-api是一個Yii2框架的擴展,用于配置完善Yii2,以實現api的快速開發。 此擴展默認的場景是APP的后端接口開發,因此偏向于實用主義,并未完全采用restfull的標準,方便前端開發處理接口數據以及各種…

.NET6打包部署到Windows Service

1.安裝Nuget包安裝以下nuget包支持windows service<PackageReference Include"Microsoft.AspNetCore.Hosting.WindowsServices" Version"6.0.10" /> <PackageReference Include"Microsoft.Extensions.Hosting.WindowsServices" Version…

傳統家電在智能家居變革的五大優勢

而在眾多向智能家居領域轉型變革的企業中&#xff0c;看似落后的傳統家電企業&#xff0c;卻占據著一定的優勢。 產品優勢 傳統家電企業在產品上的優勢主要體現在企業擁有產品本身的設計、技術、生產、制造和營銷渠道&#xff0c;其產品不論是從外觀設計、零件制造還是零件組裝…

《Apache Kafka實戰》讀書筆記-調優Kafka集群

《Apache Kafka實戰》讀書筆記-調優Kafka集群 作者&#xff1a;尹正杰 版權聲明&#xff1a;原創作品&#xff0c;謝絕轉載&#xff01;否則將追究法律責任。 一.確定調優目標 1>.常見的非功能性要求 一.性能&#xff08;performance&#xff09;最重要的非功能性需求之一。…

android emoji unicode編碼表,unicode編碼

unicode編碼app是一款字符查找客戶端應用&#xff0c;通過unicode編碼可以方便尋找特定字符&#xff0c;查看字符表情詳細的描述&#xff0c;并且利用unicode編碼就可以快捷復制任意unicode編碼&#xff0c;提高開發效率&#xff0c;非常的實用&#xff0c;快來下載unicode編碼…

物聯網商機誘人 芯片商大力搭建生態系統

應用需求變化多端的物聯網&#xff0c;雖具備龐大的發展潛力及應用商機&#xff0c;但由于市場過于分散&#xff0c;幾乎沒有殺手應用可言&#xff0c;因此對有意耕耘相關市場的半導體業者而言&#xff0c;如何借力使力&#xff0c;尋找盟友共同搭建出的生態系統&#xff0c;遂…

ASP.NET Core 6框架揭秘實例演示[30]:利用路由開發REST API

借助路由系統提供的請求URL模式與對應終結點之間的映射關系&#xff0c;我們可以將具有相同URL模式的請求分發給與之匹配的終結點進行處理。ASP.NET的路由是通過EndpointRoutingMiddleware和EndpointMiddleware這兩個中間件協作完成的&#xff0c;它們在ASP.NET平臺上具有舉足輕…

數據庫(二)tab補全功能,使數據庫支持簡體中文,日志管理,備份腳本

一、如何在MySQL數據庫中使用tab鍵補全功能 1.修改主配置文件/etc/my.cnf vim /etc/my.cnf [mysql] #no-auto-rehash auto-rehash 2.重啟MySQL服務&#xff0c;登錄測試 /etc/init.d/mysqld restart mysql -uroot -p (可在數據庫中使用tab鍵&#xff09; 3.&#xff1b;臨時支持…

php new self()關鍵字的用法

今天開框架源碼&#xff0c;發現有用到new self()的用法 有點不懂 在網上查了一下&#xff0c;給大家說一下&#xff1a; 在類中 self的用法 和this的用法差不多 &#xff0c; php new self() 一般在類內部使用&#xff0c;作用是對自身類實例化&#xff0c;下面給個實例講解…

android listview item置頂,ListView的item置頂

ListView的item設置置頂1.activitypublic class TopListViewActivity extends Activity {private static int ON_TOP 1;private static int CANCEL_TOP 0;public static String TOP_STATES "TOP";private ListView mListView;private List sessionList;private Se…

電信運營商x86服務器定制策略

近幾年&#xff0c;伴隨云計算、大數據、移動互聯網、物聯網等新技術從概念到實踐&#xff0c;業務、用戶數據海量式爆發增長&#xff0c;作為承載這些業務發展的服務器行業也面臨巨大的機遇和挑戰。一方面&#xff0c;需求的爆發式增長大幅提升了市場空間&#xff0c;尤其是大…

企業數字化轉型服務+方案

前言&#xff1a;本文的閱讀對象是公司老板、或企業高層管理者&#xff01;1【背景介紹】數字經濟與實體經濟深度融合是助推我國經濟高質量發展的重要環節。為加快數字中國建設&#xff0c;中央和地方政府都出臺各類政策扶植數字化轉型相關項目。馬云在接受采訪時也提到&#x…

在 MongoDB 上模擬事務操作來實現支付

我們的產品叫「學海密探」&#xff0c;屬于在線教育行業&#xff0c;產品需要有支付功能&#xff0c;然而支付最蛋疼是什么&#xff1f;有人會說是支付寶和微信等支付接口的接入開發&#xff01;沒錯&#xff0c;但支付接口的開發算是比較簡單的了&#xff0c;我覺得凡是跟錢有…

Zabbix server is not running

問題描述 Dashbord中提示Zabbix server is not running 分析過程 首先查看zabbix-server的運行狀態 systemctl status zabbix-server 確定是否是active(running)狀態&#xff0c;如果不是&#xff0c;重啟zabbix-server查看log tail -f /var/log/zabbix/zabbix_server.log 導致…

android 把異常寫入到文本里,嘗試在Android中將文件寫入sdcard時發生FileNotFoundException(權限被拒絕)...

從標題中可以看到&#xff0c;我在Android中將文件寫入sdcard時遇到問題.我想寫入將在sdcard上的公共空間中的文件&#xff0c;以便任何其他應用程序都可以讀取它。首先&#xff0c;我檢查sdcard是否已安裝&#xff1a;Environment.getExternalStorageState();然后&#xff0c;…

.NET性能優化-使用ValueStringBuilder拼接字符串

前言這一次要和大家分享的一個Tips是在字符串拼接場景使用的&#xff0c;我們經常會遇到有很多短小的字符串需要拼接的場景&#xff0c;在這種場景下及其的不推薦使用String.Concat也就是使用運算符。 目前來說官方最推薦的方案就是使用StringBuilder來構建這些字符串&#xff…