Python3OS
Last updated
Last updated
[TOC]
os.open() 方法用于打开一个文件,并且设置需要的打开选项,模式参数mode参数是可选的,默认为 0777。返回值是文件描述符(一个整数)
参数
file -- 要打开的文件
flags -- 该参数可以是以下选项,多个使用 "|" 隔开:
os.O_RDONLY: 以只读的方式打开
os.O_WRONLY: 以只写的方式打开
os.O_RDWR : 以读写的方式打开
os.O_NONBLOCK: 打开时不阻塞
os.O_APPEND: 以追加的方式打开
os.O_CREAT: 创建并打开一个新文件
os.O_TRUNC: 打开一个文件并截断它的长度为零(必须有写权限)
os.O_EXCL: 如果指定的文件存在,返回错误
os.O_SHLOCK: 自动获取共享锁
os.O_EXLOCK: 自动获取独立锁
os.O_DIRECT: 消除或减少缓存效果
os.O_FSYNC : 同步写入
os.O_NOFOLLOW: 不追踪软链接
mode -- 类似 chmod()。
关闭文件标识符:
os.close(fd)
os.closerange(fd_low, fd_high)
关闭所有文件描述符,从fd_low(包含) 到fd_high(不包含)
os.dup(fd)
:复制文件描述符给另一个变量
os.dup2(fd, fd2)
:把fd复制给fd2
:star:通过文件标识符创建文件对象
os.fdopen(fd, [, mode[, buffsize]])
通过文件描述符创建文件对象并返回是函数open()
的别名,可接受一样参数,但第一个参数必须是整形
fd -- 打开的文件的描述符,在Unix下,描述符是一个小整数。
mode -- 可选,和 Python 内建的 open 函数一样,mode参数可以指定『r,w,a,r+,w+,a+,b』等,表示文件的是只读的还是可以读写的,以及打开文件是以二进制还是文本形式打开。这些参数和C语言中的中fopen函数中指定的mode参数类似。
bufsize -- 可选,指定返回的文件对象是否带缓冲:bufsize=0,表示没有带缓冲;bufsize=1,表示该文件对象是行缓冲的;bufsize=正数,表示使用一个指定大小的缓冲冲,单位为byte,但是这个大小不是精确的;bufsize=负数,表示使用一个系统默认大小的缓冲,对于tty字元设备一般是行缓冲,而对于其他文件则一般是全缓冲。如果这个参数没有制定,则使用系统默认的缓冲设定。
os.chroot(path)
:需要得到管理员权限
os.getcwd()
:得到当前目录
os.fchdir(fd)
: 通过文件描述符改变当前工作目录
os.chdir(path)
:改变当前目录
os.access(path, mode);
os.access() 方法使用当前的uid/gid尝试访问路径。大部分操作使用有效的 uid/gid, 因此运行环境可以在 suid/sgid 环境尝试
参数:
path -- 要用来检测是否有访问权限的路径。
mode -- mode为F_OK,测试存在的路径,或者它可以是包含R_OK, W_OK和X_OK或者R_OK, W_OK和X_OK其中之一或者更多。
os.F_OK: 作为access()的mode参数,测试path是否存在。
os.R_OK: 包含在access()的mode参数中 , 测试path是否可读。
os.W_OK 包含在access()的mode参数中 , 测试path是否可写。
os.X_OK 包含在access()的mode参数中 ,测试path是否可执行。
os.chmod() 方法用于更改文件或目录的权限。
chmod()方法语法格式如下:
path -- 文件名路径或目录路径。
flags -- 可用以下选项按位或操作生成, 目录的读权限表示可以获取目录里文件名列表, ,执行权限表示可以把工作目录切换到此目录 ,删除添加目录里的文件必须同时有写和执行权限 ,文件权限以用户id->组id->其它顺序检验,最先匹配的允许或禁止权限被应用。
stat.S_IXOTH: 其他用户有执行权0o001
stat.S_IWOTH: 其他用户有写权限0o002
stat.S_IROTH: 其他用户有读权限0o004
stat.S_IRWXO: 其他用户有全部权限(权限掩码)0o007
stat.S_IXGRP: 组用户有执行权限0o010
stat.S_IWGRP: 组用户有写权限0o020
stat.S_IRGRP: 组用户有读权限0o040
stat.S_IRWXG: 组用户有全部权限(权限掩码)0o070
stat.S_IXUSR: 拥有者具有执行权限0o100
stat.S_IWUSR: 拥有者具有写权限0o200
stat.S_IRUSR: 拥有者具有读权限0o400
stat.S_IRWXU: 拥有者有全部权限(权限掩码)0o700
stat.S_ISVTX: 目录里文件目录只有拥有者才可删除更改0o1000
stat.S_ISGID: 执行此文件其进程有效组为文件所在组0o2000
stat.S_ISUID: 执行此文件其进程有效用户为文件所有者0o4000
stat.S_IREAD: windows下设为只读
stat.S_IWRITE: windows下取消只读
os.fchmod(fd, mode)
通过文件标识符改变权限
改变文件所有者:
os.chown(path, uid, gid)
os.fchmod(fd, uid, gid)
os.fstat(fd).st_uid os.stat(path).st_uid 查看文件拥有者用户id,st_gid 查看所有者组id
os.stat() 方法用于在给定的路径上执行一个系统 stat 的调用。
stat()
方法语法格式如下:
path -- 指定路径
stat 结构:
st_mode: inode 保护模式
st_ino: inode 节点号。
st_dev: inode 驻留的设备。
st_nlink: inode 的链接数。
st_uid: 所有者的用户ID。
st_gid: 所有者的组ID。
st_size: 普通文件以字节为单位的大小;包含等待某些特殊文件的数据。
st_atime: 上次访问的时间。
st_mtime: 最后一次修改的时间。
st_ctime: 由操作系统报告的"ctime"。在某些系统上(如Unix)是最新的元数据更改的时间,在其它系统上(如Windows)是创建时间(详细信息参见平台的文档)。
使用os.statvfs(path)
os.fstatvfs(fd)
返回相应文件或者文件夹的文件系统信息返回的结构
<class os.statvfs_result>
:
f_bsize: 文件系统块大小
f_frsize: 分栈大小
f_blocks: 文件系统数据块总数
f_bfree: 可用块数
f_bavail:非超级用户可获取的块数
f_files: 文件结点总数
f_ffree: 可用文件结点数
f_favail: 非超级用户的可用文件结点数
f_fsid: 文件系统标识 ID
f_flag: 挂载标记
f_namemax: 最大文件长度
os.write() 方法用于写入字符串到文件描述符 fd 中. 返回实际写入的字符串长度。
write()方法语法格式如下:
fd -- 文件描述符。
str -- 写入的字符串。
该方法返回写入的实际位数。
以下实例演示了 write() 方法的使用:
os.read() 方法用于从文件描述符 fd 中读取最多 n 个字节,返回包含读取字节的字符串,文件描述符 fd对应文件已达到结尾, 返回一个空字符串。
read()方法语法格式如下:
fd -- 文件描述符。
n -- 读取的字节。
返回包含读取字节的字符串
以下实例演示了 read() 方法的使用:
执行以上程序输出结果为:
os.fsync(fd)
: 强制将文件标识符写入硬盘
os.fdatasync(fd)
:强制将文件写入硬盘但不更新文件状态信息,可用于刷新缓存区
os.link(src, dst)
:创建硬链接src为原地址,dst为目标地址
os.symlink(src, dst)
:创建软链接os.readlink(dst): 返回软连接指向的文件
os.rename()方法用于重命名一个文件或者目录,从src 到dst 若dst存在则抛出OSError
os.pipe()
用于创建一个管道返回一对文件描述符(r,w)分别进行读写
执行以上程序输出结果为:
os.popen(command[, mode=‘r’[, bufsize=-1]])
:
用于从一个命令打开一个管道
command -- 使用的命令。
mode -- 模式权限可以是 'r'(默认) 或 'w'。
bufsize -- 指明了文件需要的缓冲大小:0意味着无缓冲;1意味着行缓冲;其它正值表示使用参数大小的缓冲(大概值,以字节为单位)。负的bufsize意味着使用系统的默认值,一般来说,对于tty设备,它是行缓冲;对于其它文件,它是全缓冲。如果没有改参数,使用系统的默认值。
abspath(path)
:返回一个目录的绝对路径
basename(path)
:返回一个目录的基名即最后的名称
dirname(path)
:返回一个目录的目录名
realpath(path)
:返回指定文件的标准路径而不是软连接所指路径
samefile(f1, f2)
:测试两个路径是否指向同一个文件或目录
sameopenfile(fp1,fp2)
:测试两个打开的文件是否指向同一个文件
exists()
:Test whether a path exists. Return False for broken symbolic links
os.getatime(file)
:Return the last access time of a file, reported by os.stat()
os.getmtime(file)
:Return the last modification time of a file, reported by os.stat()
os.path.isabs(s)
:Test whether a path is absolute
os.path.isdir(s)
:Return true if the pathname refers to an existing directory
os.path.isfile(s)
os.path.islink(s)
(symbolic link)
os.path.ismount(path)
:是否为挂载点
os.path.join(a, *p)
os.path.split(p)
将路径以最后一个斜线为依据,分割为一个二元元组,最后一个元素可以为空
os.splitext(p)
os.system(command)
最为直接的调用可以直接进行命令行操作
subprocess()
模块直接调用命令,返回值即为系统返回,shell=True
表示直接在系统shell中运行Python文档中出于安全考虑,不建议使用shell=True。建议使用Python库来代替shell命令,或使用pipe的一些功能做一些转义。官方的出发点是好的,不过真心麻烦了很多, so....
如果你更关注命令的终端输出,可以这样
>>>subprocess.check_output(["echo", "Hello World!"])
'Hello World!\n'
>>> subprocess.check_output("exit 1", shell=True) Traceback (most recent call last): ... subprocess.CalledProcessError: Command 'exit 1' returned non-zero exit status 1
可用方法: