__file__ 变量的意思是什么?

import os


A = os.path.join(os.path.dirname(__file__), '..')


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


C = os.path.abspath(os.path.dirname(__file__))

我通常只是把它们和实际路径连接起来。但是这些语句在运行时确定 path 是有原因的,我真的很想了解 os.path模块,以便开始使用它。

347053 次浏览

在Python中,当一个模块从一个文件中加载时,__file__被设置为它的路径。然后,您可以将其与其他函数一起使用,以查找文件所在的目录。

一个一个地举例子:

A = os.path.join(os.path.dirname(__file__), '..')
# A is the parent directory of the directory where program resides.


B = os.path.dirname(os.path.realpath(__file__))
# B is the canonicalised (?) directory where the program resides.


C = os.path.abspath(os.path.dirname(__file__))
# C is the absolute path of the directory where the program resides.

你可以在这里看到从这些返回的各种值:

import os
print(__file__)
print(os.path.join(os.path.dirname(__file__), '..'))
print(os.path.dirname(os.path.realpath(__file__)))
print(os.path.abspath(os.path.dirname(__file__)))

并确保你从不同的位置运行它(比如./text.py~/python/text.py等等),看看有什么不同。

根据文档:

__file__是模块所在文件的路径名 加载,如果是从文件中加载的。__file__属性不是 用于静态链接到解释器的C模块; 对于从共享库动态加载的扩展模块,则是

.共享库文件路径名

:

__file__将是文件的“路径”,除非模块是内置的(因此列在sys.builtin_module_names中),在这种情况下,属性没有设置。

__file__与各种os.path模块结合使用,可以让所有路径相对于当前模块的目录位置。这使得你的模块/项目可以移植到其他机器上。

在你的项目中,你需要:

A = '/Users/myname/Projects/mydevproject/somefile.txt'

然后尝试将它部署到像/home/web/mydevproject/这样的部署目录的服务器上,那么你的代码将无法正确地找到路径。

我想先解决一些困惑。__file__不是通配符,而是一个属性。双下划线属性和方法按照惯例被认为是“特殊的”,用于特殊目的。

http://docs.python.org/reference/datamodel.html显示了许多特殊的方法和属性,如果不是全部的话。

在这种情况下,__file__是一个模块的属性(模块对象)。在Python中,.py文件是一个模块。所以import amodule将有一个属性__file__,在不同的情况下意味着不同的东西。

摘自以下文件:

__file__是模块被加载的文件的路径名,如果它是从一个文件中加载的。__file__属性不存在 用于静态链接到解释器的C模块;为 扩展模块从共享库动态加载,它是

.共享库文件路径名

在你的例子中,模块在全局命名空间中访问自己的__file__属性。

要查看此操作,请尝试:

# file: test.py


print globals()
print __file__

并运行:

python test.py


{'__builtins__': <module '__builtin__' (built-in)>, '__name__': '__main__', '__file__':
'test_print__file__.py', '__doc__': None, '__package__': None}
test_print__file__.py

只是在这里添加一个简短的注释(主要是回答问题的标题,而不是它的描述),关于一个可能让一些人困惑的变化。从Python 3.4开始,__file__的行为有了轻微的变化:

  • 它被设置为使用它的模块的相对路径,如果该模块是直接执行的。
  • 否则,它将被设置为文件的绝对路径。

模块__file__属性(和相关值)现在默认情况下应该总是包含绝对路径,唯一的例外是__main__.__file__,当脚本直接使用相对路径执行时。(由Brett Cannon在发行18416中贡献。)

例子:

直接调用模块x,间接调用模块y:

# x.py:
from pathlib import Path
import y
print(__file__)
print(Path(__file__))
print(Path(__file__).resolve())


# y.py:
from pathlib import Path
print(__file__)
print(Path(__file__))

运行python3 x.py将输出:

/home/aderchox/mytest/y.py
/home/aderchox/mytest/y.py
x.py
x.py
/home/aderchox/mytest/x.py

为了补充aderchox的答案,__file__变量的行为在Python 3.9中再次改变,现在它在所有情况下都是绝对路径

运行相同的示例(但为了自一致性将其复制到这里)

# x.py:
from pathlib import Path
import y
print(__file__)
print(Path(__file__))
print(Path(__file__).resolve())


# y.py:
from pathlib import Path
print(__file__)
print(Path(__file__))

现在用两个不同版本的解释器运行x.py

$ python3.8 x.py
/private/tmp/y.py
/private/tmp/y.py
x.py
x.py
/private/tmp/x.py


$ python3.9 x.py
/private/tmp/y.py
/private/tmp/y.py
/private/tmp/x.py
/private/tmp/x.py
/private/tmp/x.py
< p >来源: https://docs.python.org/3/whatsnew/3.9.html#other-language-changes < / p >