小白教程
所有教程
关于
Search
172.70.131.12
172.70.131.12
参数设置
贡献
退出
操作
编辑
移动
保护
信息
历史
删除
查看“Python3 os fdopen”的源代码
本页内容
上一节:
Python3_os_fdatasync
下一节:
Python3_os_fpathconf
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
{{DISPLAYTITLE:os.fdopen(fd[, mode[, bufsize]])}}[[Category:python3 os file methods|15]] = Python3 os.fdopen() 方法 = [[python3 os file methods|Python3 OS 文件/目录方法]] === 概述 === os.fdopen() 方法用于通过文件描述符 fd 创建一个文件对象,并返回这个文件对象。 该方法是内置函数 [[python func open|open()]] 的别名,可以接收一样的参数,唯一的区别是 fdopen() 的第一个参数必须是整型。 === 语法 === '''fdopen()'''方法语法格式如下: <sample title="" desc="" lang="python" hererun="1"> os.fdopen(fd, [, mode[, bufsize]]); </sample> === 参数 === * '''fd''' -- 打开的文件的描述符,在Unix下,描述符是一个小整数。 * '''mode''' -- 可选,和 Python 内建的 open 函数一样,mode参数可以指定『r,w,a,r+,w+,a+,b』等,表示文件的是只读的还是可以读写的,以及打开文件是以二进制还是文本形式打开。这些参数和C语言中的<stdio.h>中fopen函数中指定的mode参数类似。 * '''bufsize''' -- 可选,指定返回的文件对象是否带缓冲:bufsize=0,表示没有带缓冲;bufsize=1,表示该文件对象是行缓冲的;bufsize=正数,表示使用一个指定大小的缓冲冲,单位为byte,但是这个大小不是精确的;bufsize=负数,表示使用一个系统默认大小的缓冲,对于tty字元设备一般是行缓冲,而对于其他文件则一般是全缓冲。如果这个参数没有制定,则使用系统默认的缓冲设定。 === 返回值 === 通过文件描述符返回的文件对象。 == 以下实例演示了 fdopen() 方法的使用: == 实例(Python 3.0+) == <sample title="" desc="" lang="python" hererun="1"> #!/usr/bin/python3 import os, sys # 打开文件 fd = os.open( "foo.txt", os.O_RDWR|os.O_CREAT ) # 获取以上文件的对象 fo = os.fdopen(fd, "w+") # 获取当前位置 print ("Current I/O pointer position :%d" % fo.tell()) # 写入字符串 fo.write( "Python is a great language.\nYeah its great!!\n"); # 读取内容 os.lseek(fd, 0, 0) str = os.read(fd, 100) print ("Read String is : ", str) # 获取当前位置 print ("Current I/O pointer position :%d" % fo.tell()) # 关闭文件 os.close( fd ) print ("关闭文件成功!!") </sample> 执行以上程序输出结果为: <sample title="" desc="" lang="python" hererun="1"> Current I/O pointer position :0 Read String is : This is testPython is a great language. Yeah its great!! Current I/O pointer position :45 关闭文件成功!! </sample> [[python3 os file methods|Python3 OS 文件/目录方法]]
返回至“
Python3 os fdopen
”。
上一节:
Python3_os_fdatasync
下一节:
Python3_os_fpathconf