• Python中获取路径os.getcwd()和os.path.dirname(os.path.realpath(__file__))的区别和对比


    os.getcwd()

    os.path.dirname(os.path.realpath(__file__))

    的区别

    先给出2个目录的结构:

    (1)PycharmProjects/pythonLearn/dir/dir2/getRootPath.py

    (2)PycharmProjects/pythonLearn/getPath.py

    【1】那我们先看看第一个PycharmProjects/pythonLearn/dir/dir2/getRootPath.py,如下代码:

    [python] view plain copy
     
    1. import os    
    2.     
    3. def getCurPath1():    
    4.     cur_path = os.path.dirname(os.path.realpath(__file__))    
    5.     return cur_path    
    6.     
    7. def getCurPath2():    
    8.     cur_path = os.getcwd()    
    9.     return cur_path    
    10.     
    11.     
    12. print('func1----'+getCurPath1())    
    13. print('func2----'+getCurPath2())    

    我们直接执行该脚本得到的结果如下:

    func1----C:UsersAdministratorPycharmProjectsPythonLearndirdir2

    func2----C:UsersAdministratorPycharmProjectsPythonLearndirdir2

    并未看出本质区别,获取的都是当前脚本所在的dir2目录。

    【2】那我们再看看第二个PycharmProjects/pythonLearn/getPath.py,如下代码:

    现在,我们在里面我们引入了PycharmProjects/pythonLearn/dir/dir2/目录下的getRootPath.py模块。

    [python] view plain copy
     
    1. from dir.dir2 import getRootPath    
    2.     
    3. path1 = getRootPath.getCurPath1()    
    4. path2 = getRootPath.getCurPath2()    

    直接执行getPath.py文件获取的结果如下:

    func1----C:UsersAdministratorPycharmProjectsPythonLearndirdir2

    func2----C:UsersAdministratorPycharmProjectsPythonLearn

    这个时候,你有没有发现有什么不同,这里的func1就是os.path.dirname(os.path.realname(__file__))获取的__file__所在脚本的路径,也就是getRootPath.py的路径。

    而os.getcwd()获取的当前最外层调用的脚本路径,即getPath所在的目录也可描述为起始的执行目录,A调用B,起始的是A,那么获取的就是A所在的目录路径。

    方法补充说明:

    os.path.dirname():去掉脚本的文件名,返回目录。

    os.path.dirname(os.path.realname(__file__)):指的是,获得你刚才所引用的模块 所在的绝对路径,__file__为内置属性。

  • 相关阅读:
    SQL Server 2019 安装错误
    SQL Server Cardinality Estimation 简介
    SQL Server 要避免的编程坏习惯
    SQL Server 中SET XACT_ABORT设置的作用
    SQL Server nested transaction try...catch 处理模板
    SVN迁移至gitlab
    安装单机版RabbitMQ
    校验MySQL主从数据并修复
    使用Xtrabackup对数据库进行部分备份恢复
    MySQL之Xtrabackup备份还原与binlog恢复
  • 原文地址:https://www.cnblogs.com/YingxuanZHANG/p/8805820.html
Copyright © 2020-2023  润新知