文章目录

  • 1. OS标准库简介
  • 2. OS标准库常用函数和属性
    • 2.1 文件和目录
      • 2.1.1 `os.getcwd()`
      • 2.1.2 `os.mkdir(path, mode=0o777, *, dir_fd=None)`
    • 2.2 os.path常见路径操作
      • 2.2.1 `os.path.abspath(path)`
      • 2.2.2 `os.path.basename(path)`
      • 2.2.3 `os.path.dirname(path)`
      • 2.2.4 `os.path.exists(path)`
      • 2.2.5 `os.path.isabs(path)`
      • 2.2.6 `os.path.isfile(path)`
      • 2.2.7 `os.path.isdir(path)`
      • 2.2.8 `os.path.islink(path)`
      • 2.2.9 `os.path.join(path, *paths)`
      • 2.2.10 `os.path.normcase(path)`
      • 2.2.11 `os.path.split(path)`
      • 2.2.12 `os.path.splitext(path)`
    • 2.3 其他常用命令
      • 2.3.1 `os.name`
      • 2.3.2 `os.__file__`
  • 3. 参考文献

1. OS标准库简介

顾名思义,OS表示Operating System,即操作系统。OS标准库是一个操作系统接口模块,提供一些方便使用操作系统相关功能的函数,具体安装位置可通过导入os模块查看os.__file__属性得到。当需要在Python代码中调用OS相关功能实现业务逻辑或者无法直接使用命令行工具时,我们就需要考虑导入此模块,因此有必要进行深入学习。

2. OS标准库常用函数和属性

2.1 文件和目录

2.1.1 os.getcwd()

返回表示当前工作目录的字符串

print("当前工作目录为:{}".format(os.getcwd())) # 返回当前工作目录

2.1.2 os.mkdir(path, mode=0o777, *, dir_fd=None)

以指定数字表示的权限模式mode创建一个名为path的目录。某些系统会忽略 mode,如果没有忽略,那么Linux系统来说,新建文件夹的权限=指定数字表示的权限模式mode-当前系统用户的umask默认权限,如下所示

"""
Linux操作系统可通过umask命令获得4个八进制数表示的默认权限,root用户默认是0022,普通用户默认是 0002
第1位数代表文件所具有的特殊权限(SetUID、SetGID、Sticky BIT),后3位数表示表示umask权限值
分别对应所有者、用户组、其他人的权限值,权限与数字对应关系为:r->4,w->2,x->1
"""
exit_code=os.system("umask")

"""
文件夹模式mode赋值为十进制511,等价于八进制0o777
"""
set_mode=511
os.mkdir(path="./cyr",mode=set_mode) # 在当前目录创建名为cyr的文件夹
# 长格式查看新创建的文件夹cyr可知其权限字符串为rwxr-xr-x,等价于转换后的数字权限111101101
!ls -l | grep cyr

umask_value=0o0022 # 当前系统用户八进制表示umask默认权限
new_dir_mode=set_mode-umask_value
print("新建文件夹的权限为:{:b}".format(new_dir_mode))

  • os.rmdir(path, *, dir_fd=None)

    移除(删除)目录 path。如果目录不存在或不为空,则会分别抛出 FileNotFoundErrorOSError 异常。

    os.rmdir("./cyr") # 删除空文件夹成功,无法查到cyr目录
    !ls | grep cyr
    
    os.rmdir("./why") # 删除不存在的文件夹FileNotFoundError报错
    

os.rmdir("./nnunet/") # 删除不为空文件夹OSError报错

  • os.chdir(path)

    将当前工作目录更改为 path

    print("切换前的当前工作目录为:{}".format(os.getcwd())) # 返回当前工作目录
    dst_path="/root" # 目标文件夹
    os.chdir(dst_path) # 将当前工作目录切换为/root
    print("切换后的当前工作目录为:{}".format(os.getcwd())) # 返回当前工作目录
    

  • os.listdir(path='.')

    返回一个包含指定path下所有文件和目录名称的按任意顺序排列的列表,特殊条目’.‘和’…'除外

    dst_path="/code/" # 目标目录
    dirs_ls=os.listdir(path=dst_path) # 获得指定目录下全部文件和文件夹名称列表
    print(dirs_ls)
    

2.2 os.path常见路径操作

2.2.1 os.path.abspath(path)

返回路径path 的绝对路径(标准化的),相当于字符串拼接,路径path不存在也不会报错

relative_path="tests/test_steps_for_sliding_window_prediction.py" # 路径path存在
print("{}对应的绝对路径为{}".format(relative_path,os.path.abspath(relative_path)))

no_path="tests/none.py" # 路径path不存在
print("{}对应的绝对路径为{}".format(relative_path,os.path.abspath(no_path)))

2.2.2 os.path.basename(path)

返回路径 path 的基本名称

full_pathname="/proc/bus/pci/3a/08.0" # 路径path存在
print("全路径名称对应的文件名为{}".format(os.path.basename(full_pathname)))

no_full_pathname="/demo/none.cpp" # 路径path不存在
print("全路径名称对应的文件名为{}".format(os.path.basename(no_full_pathname)))

2.2.3 os.path.dirname(path)

返回路径 path 的目录名称

full_pathname="/proc/bus/pci/3a/08.0" # 路径path存在
print("全路径名称对应的目录名称为{}".format(os.path.dirname(full_pathname)))

no_full_pathname="/demo/none.cpp" # 路径path不存在
print("全路径名称对应的目录名称为{}".format(os.path.dirname(no_full_pathname)))

2.2.4 os.path.exists(path)

判断path是否指向一个已存在路径或已打开的文件描述符,存在返回True,不存在返回False

full_pathname="/proc/bus/pci/3a/08.0" # 路径path存在
print("全路径名称对应的目录是否存在?{}".format(os.path.exists(full_pathname)))

no_full_pathname="/demo/none.cpp" # 路径path不存在
print("全路径名称对应的目录是否存在?{}".format(os.path.exists(no_full_pathname)))

2.2.5 os.path.isabs(path)

判断path是否为一个绝对路径,是则返回True,不是或不存在则返回False。在 Unix 上,它就是以斜杠开头,而在 Windows 上,它可以是去掉驱动器号后以斜杠(或反斜杠)开头。

abs_pathname="/proc/bus/pci/3a/08.0" # 路径path存在
print("全路径名称对应的目录是否为绝对路径?{}".format(os.path.isabs(abs_pathname)))

rel_pathname="./nnunet/__init__.py" # 路径path是相对路径
print("全路径名称对应的目录是否绝对路径?{}".format(os.path.isabs(rel_pathname)))

no_pathname="./nnunet/none.py" # 路径path是不存在
print("全路径名称对应的目录是否绝对路径?{}".format(os.path.isabs(no_pathname)))

2.2.6 os.path.isfile(path)

若path为指向一个已存在文件的符号链接或一个已存在文件路径,返回True。若path为一个文件夹路径或不存在路径,返回False。

ls -li /opt/conda/bin/python* # 带inode节点信息并长格式查看python开头的文件和文件夹

由上图可发现/opt/conda/bin/python为一个符号链接(软链接)指向一个已存在文件路径/opt/conda/bin/python3.7

abs_pathname="/opt/conda/bin/python3.7" # path为一个已存在文件路径
print("全路径名称对应的文件是否存在?{}".format(os.path.isfile(abs_pathname)))

symbolic_link="/opt/conda/bin/python" # path为指向一个已存在文件/opt/conda/bin/python3.7的符号链接
print("全路径名称对应的文件是否存在?{}".format(os.path.isfile(symbolic_link)))

abs_path="/opt/conda/bin/" # 文件夹路径
print("全路径名称对应的文件是否存在?{}".format(os.path.isfile(abs_path)))

no_full_pathname="/demo/none.cpp" # 路径path不存在
print("全路径名称对应的文件是否存在?{}".format(os.path.isfile(no_full_pathname)))

2.2.7 os.path.isdir(path)

若path为指向一个已存在文件夹的符号链接或一个已存在文件夹路径,返回True。若path为一个文件路径或不存在路径,返回False。

ls /code/nnunet/ # 查看已存在文件夹路径/code/nnunet/

ln -s /code/nnunet/ ./symlink2codennunet # 当前目录即root下创建一个软链接指向一个已存在文件夹路径/code/nnunet/
ls -l /root/

由上图可知root用户主目录下存在一个软链接symlink2codennunet指向一个已存在文件夹路径

exist_dir_path="/code/nnunet/"# path为一个已存在文件夹路径
print("全路径名称对应的文件夹是否存在?{}".format(os.path.isdir(exist_dir_path)))

exist_dir_symlink="/root/symlink2codennunet/"# path为指向一个已存在文件夹的符号链接
print("全路径名称对应的文件夹是否存在?{}".format(os.path.isdir(exist_dir_symlink)))

exist_file_path="/opt/conda/bin/python3.7"# path为一个已存在文件路径
print("全路径名称对应的文件夹是否存在?{}".format(os.path.isdir(exist_file_path)))

no_path="/demo/none.cpp" # 路径path不存在
print("全路径名称对应的文件夹是否存在?{}".format(os.path.isdir(no_path)))

2.2.8 os.path.islink(path)

若path代表一个已存在的符号链接,则返回True,反之则返回False。如果 Python 运行时不支持符号链接,则总是返回 False

exist_symbolic_link="/opt/conda/bin/python" # path为指向一个已存在的符号链接
print("全路径名称对应的符号链接是否存在?{}".format(os.path.islink(exist_symbolic_link)))

no_symbolic_link="/demo/no_link" # path为指向一个不存在的符号链接
print("全路径名称对应的符号链接是否存在?{}".format(os.path.islink(no_symbolic_link)))

exist_file_path="/opt/conda/bin/python3.7"# path为一个已存在文件路径
print("全路径名称对应的符号链接是否存在?{}".format(os.path.islink(exist_file_path)))

exist_dir_path="/root/"# path为一个已存在文件夹路径
print("全路径名称对应的符号链接是否存在?{}".format(os.path.islink(exist_dir_path)))

2.2.9 os.path.join(path, *paths)

拼接两个或多个路径部分,按需要插入/。如果参数中某个部分是绝对路径,则绝对路径前的路径都将被丢弃,并从绝对路径部分开始连接。如果最后一部分为空,则结果将以分隔符结尾。

previous_path,abs_dirname,basename,empty_part="model","/code","demo.py",""
print("参数中某个部分是绝对路径拼接后为{}".format(os.path.join(previous_path,abs_dirname,basename)))

print("拼接两个或多个路径部分,按需要插入'/'拼接后为{}".format(os.path.join(previous_path,basename)))

print("最后一部分为空以分隔符结尾{}".format(os.path.join(previous_path,basename,empty_part)))

2.2.10 os.path.normcase(path)

规范路径名称的大小写。 在 Windows 上,将路径名称中的所有字符转为小写,并将正斜杠转为反斜杠。 在其他操作系统上,将路径不加修改地返回。

Linux操作系统

print("当前操作系统模块名为:{}".format(os.name))
windows_style_path=r"C:/Users\defaultuser0/APPData"
print("Windows路径规范化后为{}".format(os.path.normcase(windows_style_path)))

Windows操作系统

2.2.11 os.path.split(path)

将路径 path 拆分为一对,即 (head, tail),其中,tail 是路径的最后一部分,而 head 里是除最后部分外的所有内容。tail 部分不会包含斜杠,如果 path 以斜杠结尾,则 tail 将为空。如果 path 中没有斜杠,head 将为空。如果 path 为空,则 head 和 tail 均为空。head 末尾的斜杠会被去掉,除非它是根目录(即它仅包含一个或多个斜杠)。

norm_path="/nnunet/configuration.py" # 一般路径
ends_with_slash_path="/code/nnunet/" # 以斜杠结尾的路径
no_slash_path="HIP_Logo.png" # 没有斜杠的路径
empty_path="" # 空路径
root_path="/" # 根目录
print("一般路径head={},tail={}".format(*os.path.split(norm_path)))
print("以斜杠结尾的路径head={},tail={}".format(*os.path.split(ends_with_slash_path)))
print("没有斜杠的路径head={},tail={}".format(*os.path.split(no_slash_path)))
print("空路径head={},tail={}".format(*os.path.split(empty_path)))
print("根目录head={},tail={}".format(*os.path.split(root_path)))

2.2.12 os.path.splitext(path)

将路径 path 拆分为一对,即 (root, ext),使 root + ext == path,其中 ext 为空或以英文句点开头,且最多包含一个句点。路径前的句点将被忽略,例如 splitext(‘.cshrc’) 返回 (‘.cshrc’, ‘’)。

dir_path="/code/nnunet/" # 文件夹路径
multi_dot_file_path="/code/i.thy.py" # 包含多个句点的文件路径
single_dot_file_path="/code/we.py" # 包含单个句点的文件路径
starts_with_dot_file_path=".bashrc" # 以句点开头的路径
print("文件夹路径root={},ext={}".format(*os.path.splitext(dir_path)))
print("包含多个句点的文件路径root={},ext={}".format(*os.path.splitext(multi_dot_file_path)))
print("包含单个句点的文件路径root={},ext={}".format(*os.path.splitext(single_dot_file_path)))
print("以句点开头的路径root={},ext={}".format(*os.path.splitext(starts_with_dot_file_path)))

2.3 其他常用命令

2.3.1 os.name

导入的依赖特定操作系统的模块的名称,返回’posix’表示Linux,'nt’表示Windows,'java’表示Java虚拟机

print("当前操作系统平台名称为{}".format(os.name))

2.3.2 os.__file__

以字符串形式返回os模块安装的绝对路径

     import osprint("os模块安装绝对路径是{}".format(os.__file__))

3. 参考文献

  • os — 操作系统接口模块 — Python 3.7.13 文档
  • os.path — 常见路径操作 — Python 3.7.13 文档
  • Linux umask详解:令新建文件和目录拥有默认权限 (biancheng.net)
  • Linux chmod命令:修改文件或目录的权限 (biancheng.net)

Python标准库之os相关推荐

  1. Python标准库中os模块的environ获取系统的环境变量

    应用背景:我们想要用Python获取到一些有关系统的各种环境变量信息的时候可以考虑使用Python标准库中的os模块的environ.什么是环境变量,环境变量是程序和操作系统之间的通信方式.有些字符不 ...

  2. Python 标准库之 os (获取当前目录、读取/设置环境变量、重命名文件、运行shell命令、创建/删除/查看目录文件、判断目录/文件/存在、获取绝对路径、获取文件名、获取换行符、获取路径分隔符)

    1. os与sys模块的官方解释如下: os This module provides a portable way of using operating system dependent funct ...

  3. 【python标准库】os.path详解

    文章目录 os中的path 输入为路径字符串的单参函数 与文件信息相关的单参函数 输入为多个参数的函数 os中的path 查看源码会看到,在os.py中有这样几行 if 'posix' in _nam ...

  4. python 标准库之os

    os.walk() 这个函数yield一个3-tuple(dirpath, dirnames, filenames) 解释 dirnames is a list of the names of the ...

  5. Python标准库03 路径与文件 (os.path包, glob包)

    摘要:Python标准库 文件系统 os.path glob.glob os.path包 os.path包主要是处理路径字符串,比如说'/home/vamei/doc/file.txt',提取出有用信 ...

  6. Python 标准库之 sys 模块详解

    Python sys 模块详解 1. 简介 "sys"即"system","系统"之意.该模块提供了一些接口,用于访问 Python 解释器 ...

  7. Python标准库04 文件管理 (部分os包,shutil包)

    摘要:Python标准库 os包: rmdir, mkdir, listdir, remove, rename, chmod, chown, stat, symlink shutil包: copy, ...

  8. Python标准库07 信号 (signal包,部分os包)

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在了解了Linux的信号基础之后,Python标准库中的signal包就很容易学习 ...

  9. python标准库os的方法listdir_使用python标准库快速修改文件名字

    大家在追剧的时候会一次性下载很多电影,但是很烦人的是前面会有很多电影网站的广告前缀. 今天我将介绍一个简短的代码,快速修改这些文件的名字. 工具:os 首先在电影目录下新建一个py文件,并导入os i ...

最新文章

  1. 用C语言解“然后是几点”问题
  2. arcgis的python脚本-在ArcGIS中写python脚本读取shapefile
  3. 基于MongoDb的S3实现
  4. hdu 4607 Park Visit 求树的直径
  5. python使用redis队列_Python的Flask框架应用调用Redis队列数据的方法
  6. java基础知识之初识java
  7. kali怎么成为管理员_网站死链是什么、是怎么引起的以及死链对SEO优化的影响?...
  8. 将Java向前推进? 一个定义。 一年回顾。
  9. axure中备注线_1分钟K线、日K线、月K线……不同周期的K线图到底有啥用?
  10. HTML笔记——bootstrap-select、table、tableExport、layer
  11. 第45届国际大学生程序设计竞赛(ICPC)银川站太原理工大学收获4枚奖牌
  12. sql运算符_SQL运算符
  13. 数据结构 /ord ;集合;dict()
  14. mac的obs录制不到全屏
  15. 基于自抗扰控制的压力环控制算法研究
  16. 【日志分析】Window日志分析
  17. 三个百分数相乘计算机,我的公考笔记:资料分析的三个速算技巧
  18. [YNOI2017]由乃的商场之旅 莫队
  19. 深度伪造检测论文 · Combining EfficientNet and Vision Transformers for Video Deepfake Detection
  20. D语言和Go语言有前途吗?

热门文章

  1. 新概念二册 Lesson 40 food and talk进餐与交谈( 现在进行时vs将来进行时+虚拟语气假设现在)
  2. vs2013版MFC按钮为灰色
  3. 六级备考28天|CET-6|听力第二讲|长对话满分技巧|听写技巧|2022年6月考题|14:30~16:00
  4. matlab求离差阵,基于离差最大化的区间多属性决策分析及matlab应用
  5. Unity打包安卓如何存储本地游戏数据?
  6. 一文读懂 NB-IoT 的现状、挑战和前景
  7. Lesson 1 Nehe
  8. VR全景图拍摄制作和传统摄影的区别
  9. 十年修得同船渡 ——苏宁与齐治的故事
  10. 关于5G,一篇讲得很透彻的文章