获取当前脚本目录路径问题汇总

20221026

    image_backup_path = os.path.abspath(os.path.join(os.getcwd(), "../"))
    获取上层目录,上层路径

20211223

https://blog.csdn.net/qq_43178297/article/details/88053836
获取上一层目录

import os
 
print('***获取当前目录***')
print(os.getcwd())
print(os.path.abspath(os.path.dirname(__file__)))
 
print('***获取上级目录***')
print(os.path.abspath(os.path.dirname(os.path.dirname(__file__))))
print(os.path.abspath(os.path.dirname(os.getcwd())))
print(os.path.abspath(os.path.join(os.getcwd(), "..")))
 
print('***获取上上级目录***')
print(os.path.abspath(os.path.dirname(os.path.dirname(__file__))))
print(os.path.abspath(os.path.join(os.getcwd(), "../..")))
import os
import os.path
from pathlib import Path
sys = platform.system()
if sys == "Windows":
    PATH = os.path.abspath(str(Path('').absolute())) + '/'
else:
    PATH = '/data/engine-company-name-match/'
target_path = PATH + '/log'
 if os.path.exists(target_path):
     pass
 else:
     os.mkdir(target_path)
判断目录是否存在,如果不存在则新建

20210811

          for name in  os.listdir('./'):
              if name==self.cookie_file:
                  os.remove('./'+str(self.cookie_file))
windows获取当前路径  './'

20210725

在这里插入图片描述
相对路径 以当前根目录为基准

20210618

    import os
    base_dir=os.path.dirname(__file__)

在这里插入图片描述
最近的source 路径

20210601

import os
from pathlib import Path
fpath=os.path.abspath(str(Path('.').absolute()))
aa=os.path.join(fpath, 'config.yml')

重点

20210323

在这里插入图片描述
当前磁盘分区的根目录 比如 C:\

20210129

在这里插入图片描述
直接就是与当前目录平级


import path

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

path文件为字节防止的空文件

    base_path=os.path.abspath(os.path.join(os.getcwd(),"../.."))  
    #后面的两对点号 相当于回退了两层
 通过此方法获取当前路径 只有在控制台转到这个当前目录才行
 

os.getcwd():仅仅获得程序运行的当前目录所在位置(如果你在a目录下执行某脚本,无论脚本调用了那些,返回的目录仍然是a)

sys.argv[0]  = sys.path[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]


其中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的所在目录
 

20201231 注意加在路径中间的 符号 左右两边都要需要正斜杠
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值