1、目录操作

1.1、获取当前目录

# coding:utf-8
import os
# 获取当前工作目录(绝对路径)
print(os.getcwd()) # E:\new\pythonProject\Blog
# 获取当前工作目录(绝对路径),值以Unicode编码返回
print(os.getcwdb()) # b'E:\\new\\pythonProject\\Blog'
# 获取当前目录,以 "."表示
print(os.curdir) # .
# 获取当前目录的上级目录,以 ".."表示
print(os.pardir) # ..

1.2、创建目录

# coding:utf-8
import os
# 创建目录, 路径可以是绝对路径也可以是相对路径, linux系统运行的程序还需指定mode参数,即文件夹的权限
# 文件目录存在时,再次创建会执行报错,因此实际开发中创建目录需判断目录是否存在
if os.path.lexists('./test'): # 判断'./test' 是否存在
print("./test已经存在")
else:
os.mkdir('./test') # 穿件 './test' 目录, "."代表当前目录,等效于 os.mkdir('test')
print(os.listdir("E:\\new\\pythonProject\\Blog"))
# ['config', 'config.txt', 'demo.py', 'image', 'Music', 'Python0S.py', 'test', '__init__.py']
# 递归创建目录
if os.path.lexists("E:\\new\\pythonProject\\Blog\\test\\12\\123"):
pass
else:
os.makedirs('test\\12\\123')
print(os.listdir("E:\\new\\pythonProject\\Blog\\test")) # ['12']
print(os.listdir("E:\\new\\pythonProject\\Blog\\test\\12")) # ['213']
# os.makedirs('test\\12\\123') # error FileExistsError: [WinError 183] 当文件已存在时,无法创建该文件。: 'test\\12\\123'

1.3、删除目录

# coding:utf-8
import os
# 删除单个目录
# 目录不存在时报错,删除时判断目录是否存在
# os.rmdir('test123') # FileNotFoundError: [WinError 2] 系统找不到指定的文件。: 'test123'

if os.path.lexists('test1'):
os.rmdir('test1')
else:
print("test1目录不存在")

# 非空目录报错,删除时 先判断是否是空目录,在进行删除
if os.path.lexists('test2'):
os.rmdir('test2') # OSError: [WinError 145] 目录不是空的。: 'test'
else:
print("test2目录不存在")
# 先判断目录是否存在 ,再判断目录是否非空目录,再进行相应的操作
if os.path.lexists('test'):
if os.listdir('test'):
print("test目录非空")
else:
os.rmdir('test')
else:
print("test目录不存在")

# 删除多个目录
# 目录不存在时报错,开发时判断先判断目录是否存在再进行操作
# os.removedirs('test123') # FileNotFoundError: [WinError 2] 系统找不到指定的文件。: 'test123'

if os.path.lexists('test4'):
os.removedirs('test4')
else:
print("test4目录不存在")
# 目录非空时报错,
if os.path.lexists(r"test/12/213"):
os.removedirs(r"test/12/213")
else:
print("test/12/213目录不存在") # test/12/213 test 下只有 12目录 12 只有 213目录 213目录为空,则删除test
# 删除 22 和44 目录,11目录非空(存在33目录),因此11目录保留
if os.path.lexists(r"11/22/44"):
os.removedirs(r"11/22/44")
else:
print("11/22/44目录不存在")
print(os.listdir())

1.4、重命名目录

# coding:utf-8
import os

# 目录重命名
# 语法格式 os.rename('oldName', 'newName')
# 原目录不存在时报错
# os.rename('oldTest', 'newTest') # FileNotFoundError: [WinError 2] 系统找不到指定的文件。: 'oldTest' -> 'newTest'
if os.path.lexists('oldTest'):
os.rename('oldTest', 'newTest')
else:
print('oldTest目录不存在')
if os.path.lexists('11'):
os.rename('11', 'newTest')
else:
print('11目录不存在')

1.5、切换目录

# coding:utf-8
import os
# 变更工作目录, 将工作目录变更至 E:\new\pythonProject,在Python中"\"均有转义字符的作用,
# 因此使用"\\"将后面的"\"转移为"\"
# 从根目录起始的文件路径称之为绝对路径,根据当前位置起始的路径称之为相对路径
print(os.getcwd()) # E:\new\pythonProject\Blog
# 绝对路径
os.chdir(r"E:\new\pythonProject\Blog\newTest")
print(os.getcwd()) # E:\new\pythonProject\Blog\newTest
os.chdir(r"E:\new\pythonProject\Blog")
print(os.getcwd()) # E:\new\pythonProject\Blog
# 相对路径
os.chdir("./newTest")
print(os.getcwd()) # E:\new\pythonProject\Blog\newTest
# 切换到当前目录的上级目录
os.chdir(os.pardir)
print(os.getcwd()) # E:\new\pythonProject\Blog

1.6、获取目录下的文件内容

# coding:utf-8
import os
# 获取目录下的文件内容
# 获取指定目录下的文件夹和文件的名称;只会查找指定目录的当前目录下的文件名和文件夹名称,不会查找下级的文件名和文件夹名称
print(os.listdir("E:\\new\\pythonProject\\Blog"))
# 默认当前目录
print(os.listdir())
# 文件不存在时报错,使用时先判断目录是否存在
# print(os.listdir(r"E:\new\pythonProject\Blog1"))
# FileNotFoundError: [WinError 3] 系统找不到指定的路径。: 'E:\\new\\pythonProject\\Blog1'

if os.path.lexists(r"E:\new\pythonProject\Blog1"):
print(os.listdir(r"E:\new\pythonProject\Blog1"))
else:
print("指定的目录不存在")

1.7、判断目录是否存在

# coding:utf-8
import os
print(os.path.lexists(r'newTest')) # True
print(os.path.lexists(r'oldTest')) # False
print(os.path.lexists(r'11\oldTest')) # False

1.8、判断是否是目录

# coding:utf-8
import os
# 目录不存在 和 非目录都返回False
print(os.path.isdir(r'11')) # False
print(os.path.isdir(r'config')) # False
print(os.path.isdir(r'newTest')) # True

1.9、判断是否是绝对路径

# coding:utf-8
import os
# 路径不存在 和 非绝对路径 都返回False
print(os.path.isabs(r'11')) # False
print(os.path.isabs(r'config')) # False
print(os.path.isabs(r'newTest')) # False
print(os.path.isabs(r'E:\new\pythonProject\Blog')) # True

2、文件操作

  • 文件的IO操作完成后必须关闭连接对象
  • flags多个值时以|隔开

2.1、读写文件

# coding:utf-8
import os
# 文件操作
# 文件的IO操作完成后必须关闭连接对象
# 常用格式 os.open(path, flags, mode), mode一般为Linux系统文件操作的参数 ,设置文件权限
"""
常用的flags:
os.O_RDONLY: 以只读的方式打开
os.O_WRONLY: 以只写的方式打开
os.O_RDWR : 以读写的方式打开
os.O_NONBLOCK: 打开时不阻塞
os.O_APPEND: 以追加的方式打开
os.O_CREAT: 创建或打开文件
os.O_TRUNC: 打开一个文件并截断它的长度为零(必须有写权限)
"""
# flags多个值时以|隔开
# 以只读权限打开config文件,文件不存在时报错,先判断是否存在 再进行操作,必要时需先判断是否为文件

if os.path.lexists(r'E:\new\\pythonProject\Blog\config.txt'):
fd = os.open(r'E:\new\\pythonProject\Blog\config.txt', os.O_RDONLY)
# 读取11个字符,从0开始计数
print(os.read(fd, 10)) # b'12356789ab'
os.close(fd)
else:
pass
# 写权限打开config文件
fd1 = os.open("E:\\new\\pythonProject\\Blog\\config.txt", os.O_WRONLY)
# print(os.read(fd1, 10)) # OSError: [Errno 9] Bad file descriptor
# 将文件的前N个字符替换为新的字符,替换长度由替换的内容长度决定
os.write(fd1, bytes('python', 'UTF-8')) # 文件的读写都是以字节类型存取
os.close(fd1)
# 文件存在打开,文件不存在新增
fd2 = os.open("E:\\new\\pythonProject\\Blog\\config.txt", os.O_RDWR)
print(os.read(fd2, 10))
os.write(fd2, bytes('java', 'UTF-8'))
print(os.read(fd2, 10))
os.close(fd2)
# 追加模式打开文件,必须具有写权限
fd3 = os.open("E:\\new\\pythonProject\\Blog\\config.txt", os.O_RDWR | os.O_APPEND)
print(os.read(fd3, 100))
os.write(fd2, bytes('java', 'UTF-8'))
os.close(fd2)

2.2、创建文件

# coding:utf-8
import os
"""
常用的flags:
os.O_RDONLY: 以只读的方式打开
os.O_WRONLY: 以只写的方式打开
os.O_RDWR : 以读写的方式打开
os.O_NONBLOCK: 打开时不阻塞
os.O_APPEND: 以追加的方式打开
os.O_CREAT: 创建或打开文件
os.O_TRUNC: 打开一个文件并截断它的长度为零(必须有写权限)
"""
# 创建空文件
fd = os.open("text.txt", os.O_CREAT)
os.close(fd)

# 创建文件并写入数据时须具有写权限
fd = os.open("text.txt", os.O_CREAT | os.O_RDWR)
os.write(fd, bytes('Yang', 'UTF-8'))
os.close(fd)

2.3、删除文件

# coding:utf-8
import os

# 文件不存在时报错
if os.path.lexists('text.txt'):
os.remove('text.txt')
else:
print("文件不存在")

2.4、重命名文件

# coding:utf-8
import os
# 文件不存在时报错
if os.path.lexists('text.txt'):
os.rename('text.txt', "new.txt")
else:
print("文件不存在")

2.5、文件判断

# coding:utf-8
import os
# 文件是否存在
print(os.path.exists(r"E:\new\pythonProject\Blog\config.txt")) # true
# 是否为文件
print(os.path.isfile(r"E:\new\pythonProject\Blog\config.txt")) # True

3、路径操作

# coding:utf-8
import os

# 拼接
print(os.path.join("11", '22', '33', 'server.log')) # 11\22\33\server.log
# 分离路径中的路径寄文件名
print(os.path.split(r"E:\new\pythonProject\Blog\config.txt")) # ('E:\\new\\pythonProject\\Blog', 'config.txt')
print(os.path.split(r"E:\new\pythonProject\Blog")) # ('E:\\new\\pythonProject', 'Blog')
# 获取路径中的文件名
print(os.path.basename(r"E:\new\pythonProject\Blog\config.txt")) # config.txt
# 获取路径中的路径名
print(os.path.dirname(r"E:\new\pythonProject\Blog\config.txt")) # E:\new\pythonProject\Blog
# 获取绝对路径
print(os.path.abspath(r"Blog\config.txt")) # E:\new\pythonProject\Blog\Blog\config.txt
# 分离文件拓展名
print(os.path.splitext(r"E:\new\pythonProject\Blog\config.txt")) # ('E:\\new\\pythonProject\\Blog\\config', '.txt')

4、其他

# coding:utf-8
import os

# 显示当前使用系统平台。'nt' 代表Windows,'posix' 代表Linux
print(os.name) # nt
# 分隔符
print("11"   os.altsep   'server.log') # 11/server.log
print("11"   os.path.altsep   'server.log') # 11/server.log

# 系统路径分隔符号;window为"\",linux为"/"
print(os.sep) # \
print(os.path.sep) # \
# 获取文件名称和后缀之间的间隔符号
print(os.extsep) # .
print("--------")
# 换行符
print(os.linesep)
print("110"   os.linesep   '119')
# 执行操作系统指令
os.system("dir")

到此这篇关于Python标准库os库的常用功能解析的文章就介绍到这了,更多相关Python os库 内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

Python标准库os库的常用功能解析的更多相关文章

  1. XCode 3.2 Ruby和Python模板

    在xcode3.2下,我的ObjectiveCPython/Ruby项目仍然可以打开更新和编译,但是你无法创建新项目.鉴于xcode3.2中缺少ruby和python的所有痕迹(即创建项目并添加新的ruby/python文件),是否有一种简单的方法可以再次安装模板?我发现了一些关于将它们复制到某个文件夹的信息,但我似乎无法让它工作,我怀疑文件夹的位置已经改变为3.2.解决方法3.2中的应用程序模板

  2. Swift基本使用-函数和闭包(三)

    声明函数和其他脚本语言有相似的地方,比较明显的地方是声明函数的关键字swift也出现了Python中的组元,可以通过一个组元返回多个值。传递可变参数,函数以数组的形式获取参数swift中函数可以嵌套,被嵌套的函数可以访问外部函数的变量。可以通过函数的潜逃来重构过长或者太复杂的函数。

  3. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  4. Swift、Go、Julia与R能否挑战 Python 的王者地位

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 红薯因 Swift 重写开源中国失败,貌似欲改用 Python

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  6. 你没看错:Swift可以直接调用Python函数库

    上周Perfect又推出了新一轮服务器端Swift增强函数库:Perfect-Python。对,你没看错,在服务器端Swift其实可以轻松从其他语种的函数库中直接拿来调用,不需要修改任何内容。以如下python脚本为例:Perfect-Python可以用下列方法封装并调用以上函数,您所需要注意的仅仅是其函数名称以及参数。

  7. Swift中的列表解析

    在Swift中完成这个的最简单的方法是什么?我在寻找类似的东西:从Swift2.x开始,有一些与你的Python样式列表解析相当的东西。(在这个意义上,它更像是Python的xrange。如果你想保持集合懒惰一路通过,只是这样说:与Python中的列表解析语法不同,Swift中的这些操作遵循与其他操作相同的语法。

  8. swift抛出终端的python错误

    每当我尝试启动与python相关的swift时,我都会收到错误.我该如何解决?

  9. 在Android上用Java嵌入Python

    解决方法看看this,它适用于J2SE,你可以尝试在Android上运行.

  10. 在android studio中使用python代码构建android应用程序

    我有一些python代码和它的机器人,我正在寻找一种方法来使用android项目中的那些python代码.有没有办法做到这一点!?解决方法有两种主要工具可供使用,它们彼此不同:>QPython>Kivy使用Kivy,大致相同的代码也可以部署到IOS.

随机推荐

  1. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  2. python数学建模之三大模型与十大常用算法详情

    这篇文章主要介绍了python数学建模之三大模型与十大常用算法详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感想取得小伙伴可以参考一下

  3. Python爬取奶茶店数据分析哪家最好喝以及性价比

    这篇文章主要介绍了用Python告诉你奶茶哪家最好喝性价比最高,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧

  4. 使用pyinstaller打包.exe文件的详细教程

    PyInstaller是一个跨平台的Python应用打包工具,能够把 Python 脚本及其所在的 Python 解释器打包成可执行文件,下面这篇文章主要给大家介绍了关于使用pyinstaller打包.exe文件的相关资料,需要的朋友可以参考下

  5. 基于Python实现射击小游戏的制作

    这篇文章主要介绍了如何利用Python制作一个自己专属的第一人称射击小游戏,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起动手试一试

  6. Python list append方法之给列表追加元素

    这篇文章主要介绍了Python list append方法如何给列表追加元素,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  7. Pytest+Request+Allure+Jenkins实现接口自动化

    这篇文章介绍了Pytest+Request+Allure+Jenkins实现接口自动化的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  8. 利用python实现简单的情感分析实例教程

    商品评论挖掘、电影推荐、股市预测……情感分析大有用武之地,下面这篇文章主要给大家介绍了关于利用python实现简单的情感分析的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下

  9. 利用Python上传日志并监控告警的方法详解

    这篇文章将详细为大家介绍如何通过阿里云日志服务搭建一套通过Python上传日志、配置日志告警的监控服务,感兴趣的小伙伴可以了解一下

  10. Pycharm中运行程序在Python console中执行,不是直接Run问题

    这篇文章主要介绍了Pycharm中运行程序在Python console中执行,不是直接Run问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

返回
顶部