python标准库OS模块函数列表与实例全解

Python OS模块库详解

os就是“operating system”的缩写,顾名思义,os模块提供的就是各种 Python 程序与操作系统进行交互的接口。通过使用os模块,一方面可以方便地与操作系统进行交互,另一方面页可以极大增强代码的可移植性。如果该模块中相关功能出错,会抛出OSError异常或其子类异常。

注意

如果是读写文件的话,建议使用内置函数open();

如果是路径相关的操作,建议使用os的子模块os.path;

如果要逐行读取多个文件,建议使用fileinput模块;

要创建临时文件或路径,建议使用tempfile模块;

要进行更高级的文件和路径操作则应当使用shutil模块

Python OS常见函数列表

函数 描述
os.sep 取代操作系统特定的路径分隔符
os.name 指示你正在使用的工作平台。比如对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix'。
os.getcwd 得到当前工作目录,即当前python脚本工作的目录路径。
os.getenv()和os.putenv 分别用来读取和设置环境变量
os.listdir() 返回指定目录下的所有文件和目录名
os.remove(file) 删除一个文件
os.stat(file) 获得文件属性
os.chmod(file) 修改文件权限和时间戳
os.mkdir(name) 创建目录
os.rmdir(name) 删除目录
os.removedirs(r“c:\python”) 删除多个目录
os.system() 运行shell命令
os.exit() 终止当前进程
os.linesep 给出当前平台的行终止符。例如,Windows使用'\r\n',Linux使用'\n'而Mac使用'\r'
os.path.split() 返回一个路径的目录名和文件名
os.path.isfile()和os.path.isdir() 分别检验给出的路径是一个目录还是文件
os.path.existe() 检验给出的路径是否真的存在
os.listdir(dirname) 列出dirname下的目录和文件
os.getcwd() 获得当前工作目录
os.curdir 返回当前目录('.')
os.chdir(dirname) 改变工作目录到dirname
os.path.isdir(name) 判断name是不是目录,不是目录就返回false
os.path.isfile(name) 判断name这个文件是否存在,不存在返回false
os.path.exists(name) 判断是否存在文件或目录name
os.path.getsize(name) 或得文件大小,如果name是目录返回0L
os.path.abspath(name) 获得绝对路径
os.path.isabs() 判断是否为绝对路径
os.path.normpath(path) 规范path字符串形式
os.path.split(name) 分割文件名与目录(事实上,如果你完全使用目录,它也会将最后一个目录作为文件名而分离,同时它不会判断文件或目录是否存在)
os.path.splitext() 分离文件名和扩展名
os.path.join(path,name) 连接目录与文件名或目录
os.path.basename(path) 返回文件名
os.path.dirname(path) 返回文件路径

Python OS模块库open模式

os.mknod(“text.txt”):创建空文件

fp = open(“text.txt”,w):直接打开一个文件,如果文件不存在就创建文件

模式 描述
w 写方式
a 追加模式打开(从EOF开始,必要时创建新文件)
r+ 以读写模式打开
w+ 以读写模式打开
a+ 以读写模式打开
rb 以二进制读模式打开
wb 以二进制写模式打开 (参见 w )
ab 以二进制追加模式打开 (参见 a )
rb+ 以二进制读写模式打开 (参见 r+ )
wb+ 以二进制读写模式打开 (参见 w+ )
ab+ 以二进制读写模式打开 (参见 a+ )

Python OS模块库文件操作

方法 描述
fp.read([size]) size为读取的长度,以byte为单位
fp.readline([size]) 读一行,如果定义了size,有可能返回的只是一行的一部分
fp.readlines([size]) 把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。如果提供size参数,size是表示读取内容的总长,也就是说可能只读到文件的一部分。
fp.write(str) 把str写到文件中,write()并不会在str后加上一个换行符
fp.writelines(seq) 把seq的内容全部写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西。
fp.close() 关闭文件。python会在一个文件不用后自动关闭文件,不过这一功能没有保证,最好还是养成自己关闭的习惯。 如果一个文件在关闭后还对其进行操作会产生ValueError
fp.flush() 把缓冲区的内容写入硬盘
fp.fileno() 返回一个长整型的”文件标签“
fp.isatty() 文件是否是一个终端设备文件(unix系统中的)
fp.tell() 返回文件操作标记的当前位置,以文件的开头为原点
fp.next() 返回下一行,并将文件操作标记位移到下一行。把一个file用于for … in file这样的语句时,就是调用next()函数来实现遍历的。
fp.seek(offset[,whence]) 将文件打操作标记移到offset的位置。这个offset一般是相对于文件的开头来计算的,一般为正数。但如果提供了whence参数就不一定了,whence可以为0表示从头开始计算,1表示以当前位置为原点计算。2表示以文件末尾为原点进行计算。需要注意,如果文件以a或a+的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾。
fp.truncate([size]) 把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。

Python OS模块库目录操作

函数 描述
os.mkdir(“file”) 创建目录
shutil.copyfile(“oldfile”,”newfile”) 复制文件:oldfile和newfile都只能是文件
shutil.copy(“oldfile”,”newfile”) oldfile只能是文件夹,newfile可以是文件,也可以是目标目录
shutil.copytree(“olddir”,”newdir”) 复制文件夹.olddir和newdir都只能是目录,且newdir必须不存在
os.rename(“oldname”,”newname”) 重命名文件(目录).文件或目录都是使用这条命令
shutil.move(“oldpos”,”newpos”) 移动文件(目录)
os.rmdir(“dir”) 只能删除空目录
shutil.rmtree(“dir”) 空目录、有内容的目录都可以删
os.chdir(“path”) 转换目录,换路径

Python OS模块库实例

引入OS标准模块库

#!/usr/bin/env python
import os
print os.getcwd()        #获取当前路径
print os.listdir('/mnt')      #列出/mnt下面的所有目录和文件

print os.mkdir('lala')       #创建目录lala和haha
print os.mkdir('haha')

print os.rmdir('haha')       #删除haha

print os.rename('example.txt','back.txt')  #修改文件名

运行效果如下

root@ruanyang-HP-ProDesk-680-G2-MT:/mnt/python# python os.py
/mnt/python
['proc', 'perl_bash', 'docker', 'warn', 'blog', 'python', 'hostname', 'test', 'tags', 'perl_DB', 'shell', 'perl_test', '.vimrc~', 'club.yml', 'test.c', '.vimrc']
None
None
None
None
root@ruanyang-HP-ProDesk-680-G2-MT:/mnt/python# ls
back.txt exit.py lala modules.py os_file.py os.py sys.py

(1)os.name 返回操作系统类型

值为posix 是linux操作系统

值为nt 是windows操作系统

(2)os.uname()操作系统的详细信息

info = os.uname()
print(info)
print(info.sysname)
print(info.nodename)

(3)os.environ 返回系统的环境变量

print(os.environ)
print(os.environ.get('PATH')) #通过key值获环境变量对应的value值

(4)os.path.isabs()判断是否是绝对路径

从根开始的路径为绝对路径,不判断文件是否存在

print(os.path.isabs('/tmp/gfff'))
print(os.path.isabs('hello.jpg'))

(5)生成绝对路径

print(os.path.abspath('hello.png'))
print(os.path.join(os.path.abspath('.'),'hello'))
print(os.path.join('/home/kiosk','python.jpg'))

(6)获取目录名和文件名

filename = '/home/home/Desktop/filename'
print(os.path.basename(filename)) #获取filename文件名
print(os.path.dirname(filename)) #获取filename目录名

(7)创建目录

os.mkdir('img') #创建一个目录
os.makedirs('img/dir1/dir2') #递归创建目录
#不能递归删除目录
os.rmdir('img')

(8)创建文件和删除文件

os.mknod('00_ok.txt') #创建文件
os.remove('00_ok.txt') #删除文件

(9)文件重命名

os.rename('data.txt','data2.txt') #将data.txt文件重命名为data2.txt

(10)判断文件或目录是否存在

print(os.path.exists('data.txt')) 

(11)分离后缀名和文件名

print(os.path.splitext('hello.jpg'))

(12)将目录名和文件名分离

print(os.path.split('/tmp/hello/hello.jpg'))

(13)获取文件上次修改时间戳

print(os.path.getctime('/etc/group'))

本文主要介绍了python标准库OS模块函数列表与实例全解,更多关于python标准库OS模块的知识请查看下面的相关链接

(0)

相关推荐

  • Python标准库json模块和pickle模块使用详解

    将Python数据类型转换为其他代码格式叫做(序列化),而json就是在各个代码实现转换的中间件. 序列化要求: 1. 只能有int,str,bool,list,dict,tuple的类型支持序列化. 2. json序列化是以字符串形式出现.那么:lis= "[11,22,33]" 这样的也能称为序列化. 3. 必须将数据类型包裹在list或dict内进行转换. 4. json内部的str格式,必须以双引号来进行包裹. 5. bool值转换为小写的首字母 json.dumps 将py转

  • Python3标准库之functools管理函数的工具详解

    1. functools管理函数的工具 functools模块提供了一些工具来调整或扩展函数和其他callable对象,从而不必完全重写. 1.1 修饰符 functools模块提供的主要工具就是partial类,可以用来"包装"一个有默认参数的callable对象.得到的对象本身就是callable,可以把它看作是原来的函数.它与原函数的参数完全相同,调用时还可以提供额外的位置或命名函数.可以使用partial而不是lambda为函数提供默认参数,有些参数可以不指定. 1.1.1 部

  • python语言线程标准库threading.local解读总结

    本段源码可以学习的地方: 1. 考虑到效率问题,可以通过上下文的机制,在属性被访问的时候临时构建: 2. 可以重写一些魔术方法,比如 __new__ 方法,在调用 object.__new__(cls) 前后进行属性的一些小设置: 3. 在本库中使用的重写魔术方法,上下文这两种基础之上,我们可以想到函数装饰器,类装饰器,异常捕获,以及两种上下文的结构: 灵活运用这些手法,可以让我们在代码架构上更上一层,能够更加省时省力. from weakref import ref # ref用在了构造大字典

  • python标准库sys和OS的函数使用方法与实例详解

    python标准库sys sys模块包括了一组非常实用的服务,内含很多函数方法和变量,用来处理Python运行时配置以及资源,从而可以与前当程序之外的系统环境交互,如:python解释器. sys模块的常见函数列表(import sys): 函数 说明 dir(sys) dir()方法查看模块中可用的方法.注意:如果是在编辑器,一定要注意要事先声明代码的编码方式,否则中文会乱码. sys.argv 实现从程序外部向程序传递参数 sys.exit([arg]) 程序中间的退出,arg=0为正常退出

  • python标准库os库的函数介绍

    OS库提供通用的,基本的操作系统交互功能. -OS库是Python标准库,包含几百个函数 -常用路径操作,进程管理,环境参数等几类 -路径操作: os.path子库,处理文件路径及信息 -进程管理:启动系统中其他程序 -环境参数:获得系统软硬件信息等环境参数 os.path子库以path为入口,用于操作和处理文件路径 import os.path import os.path as op os.path.abspath(path) #返回path在当前系统中的绝对路径 os.path.normp

  • python标准库OS模块详解

    python标准库OS模块简介 os就是"operating system"的缩写,顾名思义,os模块提供的就是各种 Python 程序与操作系统进行交互的接口.通过使用os模块,一方面可以方便地与操作系统进行交互,另一方面页可以极大增强代码的可移植性.如果该模块中相关功能出错,会抛出OSError异常或其子类异常. 注意 如果是读写文件的话,建议使用内置函数open(): 如果是路径相关的操作,建议使用os的子模块os.path: 如果要逐行读取多个文件,建议使用fileinput模

  • python标准库OS模块函数列表与实例全解

    Python OS模块库详解 os就是"operating system"的缩写,顾名思义,os模块提供的就是各种 Python 程序与操作系统进行交互的接口.通过使用os模块,一方面可以方便地与操作系统进行交互,另一方面页可以极大增强代码的可移植性.如果该模块中相关功能出错,会抛出OSError异常或其子类异常. 注意 如果是读写文件的话,建议使用内置函数open(): 如果是路径相关的操作,建议使用os的子模块os.path: 如果要逐行读取多个文件,建议使用fileinput模块

  • 一篇文章带你了解python标准库--os模块

    目录 1. os库基本介绍 2. os库之路径操作 3. os库之进程管理 4. os库之环境参数 5. 案例 总结 目前,计算机上主流的操作系统有Windows.Unix.Mac OS等,os模块为多操作系统的访问提供了相关功能的支持,涉及对文件相关操作功能的实现,系统访问path路径的操作,shell命令行操作,Linux扩展属性的操作,流程管理,CPU等硬件相关信息的获取,基于操作系统的真正的随机数的操作及相关的一些系统常量进行介绍. 1. os库基本介绍 Os库提供通用的.基本的操作系统

  • Python标准库uuid模块(生成唯一标识)详解

    目录 UUID格式组成 Python 中的uuid 模块 uuid1() 中的getnode() UUID实际应用 UUID 的劣势 参考资料: 总结 UUID (Universally Unique Identifier,通用唯一标识)是一个128位的用于计算机系统中以识别信息的数目,虽然生成UUID的概率不为零,但是无限接近零,因此可以忽略不记,如此一来,每个人都可以建立不与其他人冲突的UUID. UUID格式组成 规范的文本中,UUID的十六个八位字节标识位32个十六进制(基数16)数字,

  • 代码解析python标准库logging模块

    目录 问题1:如何获取caller的(文件名,行号,函数名)? findCaller内容如下: currentframe函数的定义: 问题2: Logger对象的层级,父子关系如何实现的? Manager的getLogger()定义如下: 问题1:如何获取caller的(文件名,行号,函数名)? 当新增一条log记录时,最终将调用Logger类的_log方法,这个方法首先会创建一个LogRecord对象.LogRecord对象需要(filename, lineno, funcname)参数信息.

  • python标准库压缩包模块zipfile和tarfile详解(常用标准库)

    目录 常用的标准库 zip格式 ZipFile参数说明 操作含义 压缩方法 常用方法 tar包 和 gz.bz2.xz格式 删除压缩包中的文件 常用的标准库 在我们常用的系统windows和Linux系统中有很多支持的压缩包格式,包括但不限于以下种类:rar.zip.tar,以下的标准库的作用就是用于压缩解压缩其中一些格式的压缩包. zip格式 import zipfile zipfile模块操作压缩包使用ZipFile类进行操作,使用方法和open的使用方法很相似,也是使用r.w.x.a四种操

  • python标准库random模块处理随机数

    目录 前言 1. 常用函数 2. 不常用函数 3. 使用示例 3.1 生成随机密码 前言 random模块实现了各种分布的伪随机数生成器. 伪随机数:人类使用算法等方式,以一个基准(也被称为种子,常用的是时间戳)来构造一系列数字,这些数字的特性符合人们所理解的随机数.一旦算法和种子都确定,产生的随机数序列也是确定的,所以称为伪随机数. 1. 常用函数 常用函数 说明 random.seed(a) 设置初始化随机种子,可输出相同随机数序列:a取整数或浮点数,不设置时默认以系统时间为种子 rando

  • Python标准库:内置函数max(iterable, *[, key, default])说明

    max(arg1, arg2, *args[, key]) 本函数是迭代对象iterable进行比较,找出最大值返回.当key参数不为空时,就以key的函数对象为判断的标准. 例子: #max() array1 = range(10) array2 = range(0, 20, 3) print('max(array1)=', max(array1)) print('max(array2)=', max(array2)) print('max(array1,)=', max(array1, ke

  • Python标准库os库的常用功能解析

    目录 1.目录操作 1.1.获取当前目录 1.2.创建目录 1.3.删除目录 1.4.重命名目录 1.5.切换目录 1.6.获取目录下的文件内容 1.7.判断目录是否存在 1.8.判断是否是目录 1.9.判断是否是绝对路径 2.文件操作 2.1.读写文件 2.2.创建文件 2.3.删除文件 2.4.重命名文件 2.5.文件判断 3.路径操作 4.其他 1.目录操作 1.1.获取当前目录 # coding:utf-8 import os # 获取当前工作目录(绝对路径) print(os.getc

随机推荐