python中的項目目錄結構
一、常見的結構
關于如何組織一個較好的Python工程目錄結構,已經有一些得到了共識的目錄結構。
在Stackoverflow的這個問題上,能看到大家對Python目錄結構的討論。
這里面說的已經很好了,我也不打算重新造輪子列舉各種不同的方式,這里面我說一下我的理解和體會。
假設你的項目名為foo, 我比較建議的最方便快捷目錄結構這樣就足夠了:
Foo/ |-- bin/ | |-- foo | |-- foo/ | |-- tests/ | | |-- __init__.py | | |-- test_main.py | | | |-- __init__.py | |-- main.py | |-- docs/ | |-- conf.py | |-- abc.rst | |-- setup.py |-- requirements.txt |-- README
簡要解釋一下
bin/
: 存放項目的一些可執(zhí)行文件,當然你可以起名script/
之類的也行。foo/
: 存放項目的所有源代碼。
(1) 源代碼中的所有模塊、包都應該放在此目錄。不要置于頂層目錄。
(2) 其子目錄tests/
存放單元測試代碼;
(3) 程序的入口最好命名為main.py
。
docs/
: 存放一些文檔。setup.py
: 安裝、部署、打包的腳本。requirements.txt
: 存放軟件依賴的外部Python包列表。README
: 項目說明文件。
除此之外,有一些方案給出了更加多的內容。
比如LICENSE.txt
,ChangeLog.txt
文件等,我沒有列在這里,因為這些東西主要是項目開源的時候需要用到。
二、如何解決多次目錄下數(shù)據的導入?
1.比如main.py
導入docs文件中的conf.py中的函數(shù)
from docs improt conf #這樣的導入是不成功的
因為from導入的是該目錄即foo文件下的文件夾,docs與foo文件夾是一級的目錄導入不成功
2.解決方案
import os,sys path = os.path.join(os.path.dirname(os.path.abspath(__file__))) #返回腳本的絕對路徑 sys.path.append(path) #臨時添加搜索路徑,這種方法導入的路徑會在python程序退出后失效。 #path1=os.path.abspath(__file__) #print(path1)#當前文件的絕對路徑 #path2=os.path.dirname(os.path.abspath(__file__)) #print(path2)#當前文件的上一層目錄的絕對路徑 #path3=os.path.dirname(os.path.dirname(os.path.abspath(__file__))) #print(path3)#當前文件的上上層目錄的絕對路徑 #os.path.join()函數(shù)用于路徑拼接文件路徑
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Python實現(xiàn)可視化CSV文件中的數(shù)據
CSV文件包含許多記錄,數(shù)據分布在各行和各列中,在這篇文章中,小編主要為大家詳細介紹了Python如何實現(xiàn)可視化CSV文件中的數(shù)據,感興趣的小伙伴可以跟隨小編一起學習一下2023-11-11淺談Python 字符串格式化輸出(format/printf)
下面小編就為大家?guī)硪黄獪\談Python 字符串格式化輸出(format/printf)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07通過conda把已有虛擬環(huán)境的python版本進行降級操作指南
當使用conda創(chuàng)建虛擬環(huán)境時,有時候可能會遇到python版本不對的問題,下面這篇文章主要給大家介紹了關于如何通過conda把已有虛擬環(huán)境的python版本進行降級操作的相關資料,需要的朋友可以參考下2024-05-05