1. 程式人生 > >python 獲得當前程式的絕對路徑

python 獲得當前程式的絕對路徑

. 以前的方法

如果是要獲得程式執行的當前目錄所在位置,那麼可以使用os模組的os.getcwd()函式。

如果是要獲得當前執行的指令碼的所在目錄位置,那麼需要使用sys模組的sys.path[0]變數或者sys.argv[0]來獲得。實際上sys.path是Python會去尋找模組的搜尋路徑列表,sys.path[0]和sys.argv[0]是一回事因為Python會自動把sys.argv[0]加入sys.path。

具體來說,如果你在C:\test目錄下執行python getpath\getpath.py,那麼os.getcwd()會輸出C:\testsys.path[0]會輸出C:\test\getpath

更特別地,如果你用py2exe模組把Python指令碼編譯為可執行檔案,那麼sys.path[0]的輸出還會變化: 
如果把依賴庫用預設的方式打包為zip檔案,那麼sys.path[0]會輸出C:\test\getpath\libarary.zip; 
如果在setup.py裡面指定zipfile=None引數,依賴庫就會被打包到exe檔案裡面,那麼sys.path[0]會輸出C:\test\getpath\getpath.exe

2. 正確的方法

但以上這些其實都不是指令碼檔案所在目錄的位置。 
比如C:\test目錄下還有一個名為sub的目錄;C:\test目錄下有getpath.pysub目錄下有 sub_path.py

getpath.py呼叫sub_path.py;我們在C:\test下執行getpath.py。如果我們在 sub_path.py裡面使用sys.path[0],那麼其實得到的是getpath.py所在的目錄路徑C:\test,因為Python虛擬機器是從getpath.py開始執行的。如果想得到sub_path.py的路徑,那麼得這樣:

os.path.split(os.path.realpath(__file__))[0]
  • 1

其中file雖然是所在.py檔案的完整路徑,但是這個變數有時候返回相對路徑,有時候返回絕對路徑,因此還要用os.path.realpath()函式來處理一下。也即在這個例子裡,os.path.realpath(__file__)

輸出是C:\test\sub\sub_path.py,而os.path.split(os.path.realpath(__file__))[0]輸出才是C:\test\sub

3. 例項說明

總之,舉例來講,os.getcwd()、sys.path[0] (sys.argv[0])和file的區別是這樣的: 
假設目錄結構是: 
複製程式碼 程式碼如下:

C:test
|-getpath
    |-path.py
    |-sub
        |-sub_path.py
  • 1
  • 2
  • 3
  • 4
  • 5

然後我們在C:\test下面執行python getpath/path.py,這時sub_path.py裡面與各種用法對應的值其實是:

os.getcwd() “C:\test”,取的是起始執行目錄

sys.path[0]sys.argv[0] “C:\test\getpath”,取的是被初始執行的指令碼的所在目錄

os.path.split(os.path.realpath(__file__))[0] “C:\test\getpath\sub”,取的是file所在檔案sub_path.py的所在目錄