Python标准库os库的常用功能解析
作者:匿名V5程序员 发布时间:2021-03-06 12:32:51
标签:Python,标准库,os,库
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")
来源:https://blog.51cto.com/u_12907475/5458591
0
投稿
猜你喜欢
- 今天以一个表单的自动提交,来进一步学习selenium的用法练习目标0)运用selenium启动firefox并载入指定页面(这部分可查看本
- 本文实例讲述了Python堆排序原理与实现方法。分享给大家供大家参考,具体如下:在这里要事先说明一下我也是新手,很多东西我了解不是很深入,写
- 集群是一种技术解决方案,它将硬件和软件结合起来,为Web、Email以及数据库等服务提供高可用性和高伸缩性的架构。本文将分析集群的类型,然后
- 说明1、方差检验是用来比较两个或多个变量数据的样本,以确定它们之间的差异是简单随机的,或者是由于过程之间的显著统计差异造成的。2、自变量X是
- 本文实例讲述了Python矩阵常见运算操作。分享给大家供大家参考,具体如下:python的numpy库提供矩阵运算的功能,因此我们在需要矩阵
- Jon Wiley, User Experience Designer for Google Apps, outlined some of
- study.py内容如下#!/usr/bin/env python# -*- coding:utf-8 -*-__author__ =
- 前言:在最近做多智能车的控制时,绘制障碍物的时候发现障碍物的图层被路面图层所覆盖,一时不知道怎么解决,其实在用matplotlib.pypl
- 这是一个用python写解压大量zip脚本的说明,本人新手一个,希望能对各位有所启发。首先要注意的,在运行自己的脚本之前一定先备份或者复制出
- 一、题目描述本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。X 星球的高科技实验室中整齐地堆放着某批珍贵金属原料。每
- 本文实例讲述了Python自定义scrapy中间模块避免重复采集的方法。分享给大家供大家参考。具体如下:from scrapy import
- 一、yield迭代器在python深度学习模型读取数据时,经常遇到yield,互联网搜索后,将比较容易理解的说明记录一下。二、使用步骤1.引
- Python的创始人为荷兰人吉多·范罗苏姆 (Guido van Rossum)。 * 圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞
- 相关推荐:完整的sql中文参考手册(chm)下载 DB2 提供了关连式资料库的查询语言 sql (Structured Query
- TFRecord作为tensorflow中广泛使用的数据格式,它跨平台,省空间,效率高。因为 Tensorflow开发者众多,统一训练时数据
- 一、案例场景字段login_place,一共267725行记录,随机15条记录如下: 后续数据分析工作需要用到地理维度进行分析,所以需要把
- ajax.html <html><head> <met
- 前言最近在解决一些算法优化的问题,为了实时性要求,必须精益求精的将资源利用率用到极致。同时对算法中一些处理进行多线程或者多进程处理。在对代码
- 现在有一个xml,格式如下: 代码如下:<date> <item> <id>&nbs
- JS调试技巧技巧一:格式化压缩代码 技巧二:快速跳转到某个断点的位置右侧的Breakpoints会汇总你在JS文件所有打过的断点,点击跟ch