獲取當前指令碼目錄路徑

2021-10-11 18:16:07 字數 4335 閱讀 3008

for name in  os.listdir('./'):

if name==self.cookie_file:

os.remove('./'+str(self.cookie_file))

windows獲取當前路徑 './'

相對路徑 以當前根目錄為基準

最近的source 路徑

import os

from pathlib import path

fpath=os.path.abspath(str(path('.').absolute()))

aa=os.path.join(fpath, 'config.yml')

重點

當前磁碟分割槽的根目錄 比如 c:\

直接就是與當前目錄平級

import path

path_=os.path.split(os.path.realpath(path.__file__))[0]

pat**件為位元組防止的空檔案

base_path=os.path.abspath(os.path.join(os.getcwd(),"../.."))  

#後面的兩對點號 相當於回退了兩層

通過此方法獲取當前路徑 只有在控制台轉到這個當前目錄才行

os.getcwd():僅僅獲得程式執行的當前目錄所在位置(如果你在a目錄下執行某指令碼,無論指令碼呼叫了那些,返回的目錄仍然是a)

sys.ar**[0]  = sys.path[0]

要獲得當前執行的指令碼的所在目錄位置。實際上sys.path是python會去尋找模組的搜尋路徑列表,sys.path[0]和sys.ar**[0]是一回事,因為python會自動把sys.ar**[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]

其中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.ar**[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.ar**[0] 「c:\test\getpath」,取的是被初始執行的指令碼的所在目錄

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

20201231 注意加在路徑中間的 符號 左右兩邊都要需要正斜槓

os.getcwd():僅僅獲得程式執行的當前目錄所在位置(如果你在a目錄下執行某指令碼,無論指令碼呼叫了那些,返回的目錄仍然是a)

sys.ar**[0]  = sys.path[0]

要獲得當前執行的指令碼的所在目錄位置。實際上sys.path是python會去尋找模組的搜尋路徑列表,sys.path[0]和sys.ar**[0]是一回事,因為python會自動把sys.ar**[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]

其中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.ar**[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.ar**[0] 「c:\test\getpath」,取的是被初始執行的指令碼的所在目錄

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

Python 獲取當前指令碼檔案路徑目錄

coding cp936 importsys,os 獲取指令碼檔案的當前路徑 defcur file dir 獲取指令碼路徑 path sys.path 0 判斷為指令碼檔案還是py2exe編譯後的檔案,如果是指令碼檔案,則返回的是指令碼的目錄,如果是py2exe編譯後的檔案,則返回的是編譯後的檔案...

Python 獲取當前指令碼檔案路徑目錄

coding cp936 import sys,os 獲取指令碼檔案的當前路徑 def cur file dir 獲取指令碼路徑 path sys.path 0 判斷為指令碼檔案還是py2exe編譯後的檔案,如果是指令碼檔案,則返回的是指令碼的目錄,如果是py2exe編譯後的檔案,則返回的是編譯後的...

python 獲取當前指令碼所在路徑

coding cp936 import sys,os 獲取指令碼檔案的當前路徑 def cur file dir 獲取指令碼路徑 path sys.path 0 判斷為指令碼檔案還是py2exe編譯後的檔案,如果是指令碼檔案,則返回的是指令碼的目錄,如果是py2exe編譯後的檔案,則返回的是編譯後的...