os.path.split(os.path.realpath(__file__))[0]
1. 以前的方法
如果是要獲得程序運行的當前目錄所在位置,那么可以使用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:\test,sys.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.py,sub目錄下有 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
然后我們在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的所在目錄
原文鏈接:https://blog.csdn.net/vitaminc4/article/details/78702852