如何在Python中获取__main__模块的文件名?

Rom*_*kov 63 python python-module

假设我有两个模块:

a.py:

import b
print __name__, __file__
Run Code Online (Sandbox Code Playgroud)

b.py:

print __name__, __file__
Run Code Online (Sandbox Code Playgroud)

我运行"a.py"文件.这打印:

b        C:\path\to\code\b.py
__main__ C:\path\to\code\a.py
Run Code Online (Sandbox Code Playgroud)

问题:如何__main__从"b.py"库中获取模块的路径(在本例中为"a.py")?

iro*_*ggy 72

import __main__
print __main__.__file__
Run Code Online (Sandbox Code Playgroud)

  • `__main__`并不总是具有`__file__`属性. (21认同)
  • @ jpmc26:我不知道.要获取脚本的目录(而不是它的名称),可以使用[`get_script_dir()`](http://stackoverflow.com/a/22881871/4279) (2认同)

Jar*_*die 35

也许这会解决问题:

import sys
from os import path
print path.abspath(sys.modules['__main__'].__file__)
Run Code Online (Sandbox Code Playgroud)

请注意,为了安全起见,您应该检查__main__模块是否具有__file__属性.如果它是动态创建的,或者只是在交互式python控制台中运行,它将没有__file__:

python
>>> import sys
>>> print sys.modules['__main__']
<module '__main__' (built-in)>
>>> print sys.modules['__main__'].__file__
AttributeError: 'module' object has no attribute '__file__'
Run Code Online (Sandbox Code Playgroud)

如果您的应用程序中存在这种可能性,那么简单的hasattr()检查就可以防范方案2.

  • 假设主脚本没有 `__file__` 属性?那怎么得到路径呢?你说要检查 main 是否有 `__file__` 属性,但是你的代码没有显示如果 main 没有它该怎么办。 (2认同)

pop*_*cnt 15

下面的python代码提供了其他功能,包括它与py2exe可执行文件无缝协作.

我使用类似的代码来查找相对于运行脚本的路径,也就是说__main__.作为一个额外的好处,它适用于包括Windows在内的跨平台.

import imp
import os
import sys

def main_is_frozen():
   return (hasattr(sys, "frozen") or # new py2exe
           hasattr(sys, "importers") # old py2exe
           or imp.is_frozen("__main__")) # tools/freeze

def get_main_dir():
   if main_is_frozen():
       # print 'Running from path', os.path.dirname(sys.executable)
       return os.path.dirname(sys.executable)
   return os.path.dirname(sys.argv[0])

# find path to where we are running
path_to_script=get_main_dir()

# OPTIONAL:
# add the sibling 'lib' dir to our module search path
lib_path = os.path.join(get_main_dir(), os.path.pardir, 'lib')
sys.path.insert(0, lib_path)

# OPTIONAL: 
# use info to find relative data files in 'data' subdir
datafile1 = os.path.join(get_main_dir(), 'data', 'file1')
Run Code Online (Sandbox Code Playgroud)

希望上面的示例代码可以提供有关如何确定正在运行的脚本的路径的其他信息......


lrs*_*jng 8

另一种方法是使用sys.argv[0].

import os
import sys

main_file = os.path.realpath(sys.argv[0]) if sys.argv[0] else None
Run Code Online (Sandbox Code Playgroud)

sys.argv[0]如果Python -c从Python控制台开始或者从Python控制台检查,它将是一个空字符串.