一、os模块
os模块是与操作系统交互的一个接口。
1、os模块函数
os.access(path, mode)
# 检验权限模式os.chdir(path)
# 改变当前工作目录os.chflags(path, flags)
# 设置路径的标记为数字标记。os.chmod(path, mode)
# 更改权限os.chown(path, uid, gid)
# 更改文件所有者os.chroot(path)
# 改变当前进程的根目录os.close(fd)
# 关闭文件描述符 fdos.closerange(fd_low, fd_high)
# 关闭所有文件描述符,从 fd_low (包含) 到 fd_high (不包含), 错误会忽略os.curdir
# 返回当前目录:(’.’)os.dup(fd)
# 复制文件描述符 fdos.dup2(fd, fd2)
# 将一个文件描述符 fd 复制到另一个 fd2os.environ
# 获取系统环境变量os.fchdir(fd)
# 通过文件描述符改变当前工作目录os.fchmod(fd, mode)
# 改变一个文件的访问权限,该文件由参数fd指定,参数mode是Unix下的文件访问权限。os.fchown(fd, uid, gid)
# 修改一个文件的所有权,这个函数修改一个文件的用户ID和用户组ID,该文件由文件描述符fd指定。os.fdatasync(fd)
# 强制将文件写入磁盘,该文件由文件描述符fd指定,但是不强制更新文件的状态信息。os.fdopen(fd[, mode[, bufsize]])
# 通过文件描述符 fd 创建一个文件对象,并返回这个文件对象os.fpathconf(fd, name)
# 返回一个打开的文件的系统配置信息。name为检索的系统配置的值,它也许是一个定义系统值的字符串,这些名字在很多标准中指定(POSIX.1, Unix 95, Unix 98, 和其它)。os.fstat(fd)
# 返回文件描述符fd的状态,像stat()。os.fstatvfs(fd)
# 返回包含文件描述符fd的文件的文件系统的信息,像 statvfs()os.fsync(fd)
# 强制将文件描述符为fd的文件写入硬盘。os.ftruncate(fd, length)
# 裁剪文件描述符fd对应的文件, 所以它最大不能超过文件大小。os.getcwd()
# 返回当前工作目录os.getcwdu()
# 返回一个当前工作目录的Unicode对象os.isatty(fd)
# 如果文件描述符fd是打开的,同时与tty(-like)设备相连,则返回true, 否则False。os.lchflags(path, flags)
# 设置路径的标记为数字标记,类似 chflags(),但是没有软链接os.lchmod(path, mode)
# 修改连接文件权限os.lchown(path, uid, gid)
# 更改文件所有者,类似 chown,但是不追踪链接。os.link(src, dst)
# 创建硬链接,名为参数 dst,指向参数 srcos.listdir(path)
# 返回path指定的文件夹包含的文件或文件夹的名字的列表。os.lseek(fd, pos, how)
# 设置文件描述符 fd当前位置为pos, how方式修改: SEEK_SET 或者 0 设置从文件开始的计算的pos; SEEK_CUR或者 1 则从当前位置计算; os.SEEK_END或者2则从文件尾部开始. 在unix,Windows中有效os.lstat(path)
# 像stat(),但是没有软链接os.linesep
# 当前平台使用的行终止符,win下为”\t\n”,Linux下为”\n”os.major(device)
# 从原始的设备号中提取设备major号码 (使用stat中的st_dev或者st_rdev field)。os.makedev(major, minor)
# 以major和minor设备号组成一个原始设备号os.makedirs(path[, mode])
# 递归文件夹创建函数。像mkdir(), 但创建的所有intermediate-level文件夹需要包含子文件夹。os.minor(device)
# 从原始的设备号中提取设备minor号码 (使用stat中的st_dev或者st_rdev field )。os.mkdir(path[, mode])
# 以数字mode的mode创建一个名为path的文件夹.默认的 mode 是 0777 (八进制)。os.mkfifo(path[, mode])
# 创建命名管道,mode 为数字,默认为 0666 (八进制)os.mknod(filename[, mode=0600, device])
# 创建一个名为filename文件系统节点(文件,设备特别文件或者命名pipe)。os.open(file, flags[, mode])
# 打开一个文件,并且设置需要的打开选项,mode参数是可选的os.openpty()
# 打开一个新的伪终端对。返回 pty 和 tty的文件描述符。os.pathconf(path, name)
# 返回相关文件的系统配置信息。os.pathsep
# 用于分割文件路径的字符串os.pardir
# 获取当前目录的父目录字符串名:(‘..’)os.pipe()
# 创建一个管道. 返回一对文件描述符(r, w) 分别为读和写os.popen(command[, mode[, bufsize]])
# 从一个 command 打开一个管道os.path.abspath(path)
# 返回path规范化的绝对路径os.path.split(path)
# 将path分割成目录和文件名二元组返回os.path.dirname(path)
# 返回path的目录。其实就是os.path.split(path)的第一个元素os.path.basename(path)
# 返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素os.path.exists(path)
# 如果path存在,返回True;如果path不存在,返回Falseos.path.isabs(path)
# 如果path是绝对路径,返回Trueos.path.isfile(path)
# 如果path是一个存在的文件,返回True。否则返回Falseos.path.isdir(path)
# 如果path是一个存在的目录,则返回True。否则返回Falseos.path.join(path1[, path2[, ...]])
# 将多个路径组合后返回,第一个绝对路径之前的参数将被忽略os.path.getatime(path)
# 返回path所指向的文件或者目录的最后存取时间os.path.getmtime(path)
# 返回path所指向的文件或者目录的最后修改时间os.name
# 字符串指示当前使用平台。win->’nt’; Linux->’posix’os.read(fd, n)
# 从文件描述符 fd 中读取最多 n 个字节,返回包含读取字节的字符串,文件描述符 fd对应文件已达到结尾, 返回一个空字符串。os.readlink(path)
# 返回软链接所指向的文件os.remove(path)
# 删除路径为path的文件。如果path 是一个文件夹,将抛出OSError; 查看下面的rmdir()删除一个 directory。os.removedirs(path)
# 递归删除目录。若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推os.rename(src, dst)
# 重命名文件或目录,从 src 到 dstos.renames(old, new)
# 递归地对目录进行更名,也可以对文件进行更名。os.rmdir(path)
# 删除path指定的空目录,如果目录非空,则抛出一个OSError异常。os.sep
# 操作系统特定的路径分隔符,win下为”\“,Linux下为”/“os.stat(path)
# 获取path指定的路径的信息,功能等同于C API中的stat()系统调用。os.stat_float_times([newvalue])
# 决定stat_result是否以float对象显示时间戳os.statvfs(path)
# 获取指定路径的文件系统统计信息os.symlink(src, dst)
# 创建一个软链接os.system("bash command")
# 运行shell命令,直接显示os.tcgetpgrp(fd)
# 返回与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组os.tcsetpgrp(fd, pg)
# 设置与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组为pg。os.tempnam([dir[, prefix]])
# 返回唯一的路径名用于创建临时文件。os.tmpfile()
# 返回一个打开的模式为(w+b)的文件对象 .这文件对象没有文件夹入口,没有文件描述符,将会自动删除。os.tmpnam()
# 为创建一个临时文件返回一个唯一的路径os.ttyname(fd)
# 返回一个字符串,它表示与文件描述符fd 关联的终端设备。如果fd 没有与终端设备关联,则引发一个异常。os.unlink(path)
# 删除文件路径os.utime(path, times)
# 返回指定的path文件的访问和修改的时间。os.walk(top[, topdown=True[, onerror=None[, followlinks=False]]])
# 输出在文件夹中的文件名通过在树中游走,向上或者向下。os.write(fd, str)
# 写入字符串到文件描述符 fd中. 返回实际写入的字符串长度
2、os小示例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30 import os
os.rename(r'E:\1.txt', r'E:\2.txt') # 文件重命名
os.remove(r'E:\1.txt') # 删除文件
os.getcwd() # 获取当前目录
os.chdir(r'E:\文件夹1') # 改变默认目录
os.listdir() # 获取目录列表
os.mkdir('文件夹2') # 创建文件夹
os.rmdir('文件夹2') # 删除文件夹
os.makedirs(r'文件夹2\文件夹3\文件夹4') # 递归创建文件夹
os.removedirs(r'文件夹2\文件夹3\文件夹4') # 递归删除文件夹
os.renames(r'2\3\4',r'文件夹2\文件夹3\文件夹4') # 递归重命名文件夹,也可以对文件进行更名
os.path.abspath('.') # 查看当前目录的绝对路径
os.path.abspath('1.txt') # 获取当前文件的绝对路径
os.path.split(r'E:\1\1.txt') # 分割路径和文件名
os.path.splitext('/path/to/file.txt') # 拆分路径直接得到扩展名
os.path.join(r'E:\1', '新建文件夹', '1.txt') # 以当前操作系统的路径分隔符拼接成一个路径
os.path.dirname(r'E:\1\1.txt') # 获取指定路径的父目录
os.path.basename(r'E:\1\1.txt') # 获取指定路径的最后文件名或文件夹名
os.path.exists(r'E:\1\1.txt') # 判断目录或文件是否存在
os.path.isdir(r'E:\1') # 判断指定路径是不是一个文件夹
os.path.isfile(r'E:\1\1.txt') # 判断指定路径是不是一个文件
os.sep # 获取当前操作系统的路径分隔符,输出\
os.environ # 获取当前操作系统的环境变量
os.pathsep # 获取当前系统的环境变量中路径的分隔符,linux是:,windows是;
os.popen('adb devices').read() # 执行commond命令,需要用read系列方法获取返回值
os.system('adb devices') # 执行命令返回值只会有0(成功),1,2
二、shutil模块
高级的文件、文件夹、压缩包处理模块。
1、shutil模块函数
shutil.copyfileobj(fsrc, fdst[, length])
#将文件内容拷贝到另一个文件中shutil.copyfile(src, dst)
#拷贝文件,目标文件无需存在shutil.copymode(src, dst)
#仅拷贝权限。内容、组、用户均不变,目标文件必须存在shutil.copystat(src, dst)
#仅拷贝状态的信息,包括:mode bits, atime, mtime, flags,目标文件必须存在shutil.copy(src, dst)
#拷贝文件和权限shutil.copy2(src, dst)
#拷贝文件和状态信息shutil.ignore_patterns(*patterns)
#排除目标shutil.copytree(src, dst, symlinks=False, ignore=None)
#递归的去拷贝文件夹shutil.rmtree(path[, ignore_errors[, onerror]])
#递归的去删除文件shutil.move(src, dst)
#递归的去移动文件,它类似mv命令,其实就是重命名。shutil.make_archive(base_name, format,...)
#创建压缩包并返回文件路径,例如:zip、tar
2、shutil小示例
1
2
3
4
5
6
7
8
9
10
11
12
13 import shutil
shutil.copyfile('1.txt', '2.txt') # 拷贝文件,目标文件无需存在
shutil.copy('1.txt', '2.txt') # 拷贝文件和权限,目标文件无需存在
shutil.copy2('1.txt', '2.txt') # 拷贝文件和状态信息,目标文件无需存在
shutil.copymode('1.txt','2.txt') # 仅拷贝权限。内容、组、用户均不变,目标文件必须存在
shutil.copystat('1.txt','2.txt') # 仅拷贝状态的信息,目标文件必须存在
shutil.copytree(r'E:\1\文件夹1',r'E:\1\文件夹2') #递归拷贝文件
shutil.copytree('folder1', 'folder2', ignore=shutil.ignore_patterns('*.pyc', 'tmp*')) #目标目录不能存在,注意对folder2目录父级目录要有可写权限,ignore的意思是排除
shutil.rmtree(r'E:\1\文件夹1') # 递归删除文件
shutil.move(r'E:\1\文件夹1',r'E:\1\文件夹2') # 递归移动文件,其实就是重命名
shutil.make_archive('我是压缩包', 'zip', r'E:\1\文件夹1') # 将文件夹1下的文件压缩进“我是压缩包”
三、glob模块
glob模块提供了一个函数用于从目录通配符搜索中生成文件列表glob.glob()
1
2
3>>> import glob
>>> glob.glob('E:/test/*/*.py')
['primes.py', 'random.py', 'quote.py']
持续更新…
最后更新: 2018年12月04日 17:48