我需要获取当前登录用户的主目录位置。目前,在Linux上我一直在使用以下方法:
os.getenv("HOME")
然而,这在Windows上不起作用。正确的跨平台方式是什么?
我需要获取当前登录用户的主目录位置。目前,在Linux上我一直在使用以下方法:
os.getenv("HOME")
然而,这在Windows上不起作用。正确的跨平台方式是什么?
from os.path import expanduser
home = expanduser("~")
from pathlib import Path
home = str(Path.home())
Path.home()
转换为字符串。使用这种方式更自然:with open(Path.home() / ".ssh" / "known_hosts") as f:
lines = f.readlines()
os.path.expanduser('〜用户名')
。不过可能只适用于Linux系统。 - Maxstr
的调用)。如果你只需要路径作为字符串,它们两个都可以达到相同的效果。 - Niklas Mertschstr()
。使用斜杠 /
构建路径更加自然,例如 Path.home() / "location_of_a_file.txt"
。 - Paul Rougieux我发现pathlib模块也支持这个功能。
from pathlib import Path
>>> Path.home()
WindowsPath('C:/Users/XXX')
我知道这个帖子很旧了,但是最近我需要在一个大型项目中使用它(Python 3.8)。它必须在任何主流操作系统上运行,因此我选择了@Max在评论中提供的解决方案。
代码:
import os
print(os.path.expanduser("~"))
输出窗口:
PS C:\Python> & C:/Python38/python.exe c:/Python/test.py
C:\Users\mXXXXX
输出Linux(Ubuntu):
rxxx@xx:/mnt/c/Python$ python3 test.py
/home/rxxx
我还在 Python 2.7.17 上进行了测试,也能正常工作。
可以使用标准库中的pathlib
模块来完成此操作,它将路径视为带有方法的对象,而不是字符串。
Path.expanduser()
:展开路径中的波浪号字符(~),即将路径中的“~”替换为当前用户的主目录。Path.home()
:返回当前用户的主目录路径。from pathlib import Path
home: str = str(Path('~').expanduser())
这并不完全符合问题的要求(它被标记为跨平台
),但也许对某些人有用。
如何获取有效用户的主目录 (仅适用于Linux)。
假设您正在编写安装程序脚本或其他需要您在特定本地用户下执行某些操作的解决方案。您很可能会通过更改有效用户来完成此操作,但os.path.expanduser(“~”)
仍将返回/root
。
参数需要使用所需的用户名:
os.path.expanduser(f"~{USERNAME}/")
import os
import pwd
import grp
class Identity():
def __init__(self, user: str, group: str = None):
self.uid = pwd.getpwnam(user).pw_uid
if not group:
self.gid = pwd.getpwnam(user).pw_gid
else:
self.gid = grp.getgrnam(group).gr_gid
def __enter__(self):
self.original_uid = os.getuid()
self.original_gid = os.getgid()
os.setegid(self.uid)
os.seteuid(self.gid)
def __exit__(self, type, value, traceback):
os.seteuid(self.original_uid)
os.setegid(self.original_gid)
if __name__ == '__main__':
with Identity("hedy", "lamarr"):
homedir = os.path.expanduser(f"~{pwd.getpwuid(os.geteuid())[0]}/")
with open(os.path.join(homedir, "install.log"), "w") as file:
file.write("Your home directory contents have been altered")