如何确定:

当前目录(运行Python脚本时我在shell中的位置),以及我正在执行的Python文件在哪里?


当前回答

Python 3.4中引入的路径库模块(PEP428-路径库模块-面向对象的文件系统路径)使路径相关的体验更好。

pwd

/home/skovorodkin/stack

tree

.
└── scripts
    ├── 1.py
    └── 2.py

要获取当前工作目录,请使用Path.cwd():

from pathlib import Path

print(Path.cwd())  # /home/skovorodkin/stack

要获取脚本文件的绝对路径,请使用path.resolve()方法:

print(Path(__file__).resolve())  # /home/skovorodkin/stack/scripts/1.py

要获取脚本所在目录的路径,请访问.parent(建议在.parent之前调用.resolve()):

print(Path(__file__).resolve().parent)  # /home/skovorodkin/stack/scripts

记住__file__在某些情况下是不可靠的:如何在Python中获取当前执行文件的路径?。


请注意,Path.cwd()、Path.resolve()和其他Path方法返回路径对象(在我的例子中是PosixPath),而不是字符串。在Python 3.4和3.5中,这造成了一些麻烦,因为open内置函数只能处理字符串或字节对象,并且不支持Path对象,因此您必须将Path对象转换为字符串或使用Path.open()方法,但后一个选项要求您更改旧代码:

文件脚本/2.py

from pathlib import Path

p = Path(__file__).resolve()

with p.open() as f: pass
with open(str(p)) as f: pass
with open(p) as f: pass

print('OK')

输出

python3.5 scripts/2.py

Traceback (most recent call last):
  File "scripts/2.py", line 11, in <module>
    with open(p) as f:
TypeError: invalid file: PosixPath('/home/skovorodkin/stack/scripts/2.py')

如您所见,open(p)不适用于Python 3.5。

PEP 519-添加Python 3.6中实现的文件系统路径协议,将PathLike对象的支持添加到开放函数,因此现在可以直接将path对象传递到开放函数:

python3.6 scripts/2.py

OK

其他回答

要获取Python文件所在目录的完整路径,请在该文件中写入以下内容:

import os 
dir_path = os.path.dirname(os.path.realpath(__file__))

(请注意,如果您已经使用os.chdir()更改了当前工作目录,则上面的咒语将不起作用,因为__file__常量的值是相对于当前工作目录的,并且不会被os.chdir()调用更改。)


要获取当前工作目录,请使用

import os
cwd = os.getcwd()

上述模块、常数和函数的文档参考:

os和os.path模块。__file__常量os.path.realpath(路径)(返回“指定文件名的规范路径,消除路径中遇到的任何符号链接”)os.path.dirname(路径)(返回“路径名路径的目录名”)os.getcwd()(返回“表示当前工作目录的字符串”)os.chdir(路径)(“将当前工作目录更改为路径”)

当前工作目录:os.getcwd()

__file__属性可以帮助您找到正在执行的文件的位置。这篇StackOverflow文章解释了一切:如何在Python中获取当前执行文件的路径?

如果您使用的是Python3.4,有一个全新的高级pathlib模块,它允许您方便地调用pathlib.Path.cwd()以获取表示当前工作目录的Path对象,以及许多其他新功能。

有关此新API的更多信息,请参阅此处。

您可能会发现这是一个有用的参考:

import os

print("Path at terminal when executing this file")
print(os.getcwd() + "\n")

print("This file path, relative to os.getcwd()")
print(__file__ + "\n")

print("This file full path (following symlinks)")
full_path = os.path.realpath(__file__)
print(full_path + "\n")

print("This file directory and name")
path, filename = os.path.split(full_path)
print(path + ' --> ' + filename + "\n")

print("This file directory only")
print(os.path.dirname(full_path))

我认为找到当前执行上下文名称的最简洁方法是:

current_folder_path, current_folder_name = os.path.split(os.getcwd())