在Python中是否有通用的方法来找出当前正在执行的文件的路径?

失败的方法

Path = os.path.abspath(os.path.dirname(sys.argv[0]))

如果您正在从另一个目录中的另一个Python脚本运行,例如在2.x中使用execfile,则这将不起作用。

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

我发现这在以下情况下不起作用:

Py2exe没有__file__属性,尽管有一个变通方法 当使用execute()从IDLE运行代码时,在这种情况下没有__file__属性 在Mac OS X v10.6(雪豹)上,我得到NameError:未定义全局名称“__file__”

测试用例

目录树

C:.
|   a.py
\---subdir
        b.py

a.py的内容

#! /usr/bin/env python
import os, sys

print "a.py: sys.argv[0]=", sys.argv[0]
print "a.py: __file__=", __file__
print "a.py: os.getcwd()=", os.getcwd()
print

execfile("subdir/b.py")

subdir/b.py的内容

#! /usr/bin/env python
import os, sys

print "b.py: sys.argv[0]=", sys.argv[0]
print "b.py: __file__=", __file__
print "b.py: os.getcwd()=", os.getcwd()
print

python a.py的输出(在Windows上)

a.py: __file__= a.py
a.py: os.getcwd()= C:\zzz

b.py: sys.argv[0]= a.py
b.py: __file__= a.py
b.py: os.getcwd()= C:\zzz

相关的(但这些答案是不完整的)

查找当前运行文件的路径 当前文件的路径取决于我如何执行程序 如何知道Python中运行脚本的路径? 将directory更改为Python脚本所在目录


当前回答

如果代码来自一个文件,您可以获得它的全名

sys._getframe().f_code.co_filename

还可以将函数名检索为f_code.co_name

其他回答

这应该在跨平台的方式(只要你没有使用解释器或其他东西):

import os, sys
non_symbolic=os.path.realpath(sys.argv[0])
program_filepath=os.path.join(sys.path[0], os.path.basename(non_symbolic))

sys。路径[0]是调用脚本所在的目录(它首先查找脚本要使用的模块)。我们可以将文件本身的名称从sys的末尾去掉。argv[0](这是我对os.path.basename所做的)。Os.path.join只是将它们以跨平台的方式连接在一起。os.path。realpath只是确保如果我们得到任何符号链接,其名称与脚本本身不同,我们仍然得到脚本的真实名称。

我没有Mac电脑;所以,我还没有在一个人身上测试过。请让我知道它是否有效,因为它似乎应该。我用Python 3.4在Linux (Xubuntu)上测试了这个功能。注意,这个问题的许多解决方案在mac上不起作用(因为我听说mac上不存在__file__)。

注意,如果您的脚本是一个符号链接,它将提供它所链接到的文件的路径(而不是符号链接的路径)。

你可以使用pathlib模块中的Path:

from pathlib import Path

# ...

Path(__file__)

你可以使用call to parent在路径中更进一步:

Path(__file__).parent

这个解决方案即使在可执行文件中也是健壮的:

import inspect, os.path

filename = inspect.getframeinfo(inspect.currentframe()).filename
path     = os.path.dirname(os.path.abspath(filename))

首先,您需要从inspect和os导入

from inspect import getsourcefile
from os.path import abspath

接下来,无论您想从哪里找到源文件,只需使用

abspath(getsourcefile(lambda:0))

只需添加以下内容:

from sys import *
path_to_current_file = sys.argv[0]
print(path_to_current_file)

Or:

from sys import *
print(sys.argv[0])