1. 读写文
open() 返回一个 file object (文件对象),最常用的有两个参数: open(filename, mode)。mode模式
>>>f=open(‘文件地址’,‘模式’)
第一个参数是包含文件名的字符串。第二个参数是另一个字符串,其中包含一些描述文件使用方式的字符。mode 可以是 'r' ,表示文件只能读取,'w' 表示只能写入(已存在的同名文件会被删除),还有 'a' 表示打开文件以追加内容;任何写入的数据会自动添加到文件的末尾。'r+' 表示打开文件进行读写。mode 参数是可选的;省略时默认为 'r'。
通常文件是以 text mode 打开的,这意味着从文件中读取或写入字符串时,都会以指定的编码方式进行编码。如果未指定编码格式,默认值与平台相关 (参见 open())。在mode 中追加的 'b' 则以 binary mode(二进制模式) 打开文件:现在数据是以字节对象的形式进行读写的。这个模式应该用于所有不包含文本的文件。
在文本模式下读取时,默认会把平台特定的行结束符 (Unix 上的 \n, Windows 上的 \r\n) 转换为 \n。在文本模式下写入时,默认会把出现的 \n 转换回平台特定的结束符。这样在幕后修改文件数据对文本文件来说没有问题,但是会破坏二进制数据例如 JPEG 或 EXE 文件中的数据。请一定要注意在读写此类文件时应使用二进制模式。
在处理文件对象时,最好使用 with 关键字。 优点是当子句体结束后文件会正确关闭,即使在某个时刻引发了异常。 而且使用 with 相比等效的 try-finally 代码块要简短得多:
>>> with open('workfile') as f:
... read_data = f.read()
>>> f.closed
True
如果你没有使用 with 关键字,那么你应该调用 f.close() 来关闭文件并立即释放它使用的所有系统资源。如果你没有显式地关闭文件,Python的垃圾回收器最终将销毁该对象并为你关闭打开的文件,但这个文件可能会保持打开状态一段时间。另外一个风险是不同的Python实现会在不同的时间进行清理。
通过 with 语句或者调用 f.close() 关闭文件对象后,尝试使用该文件对象将自动失败。:
>>> f.close()
>>> f.read()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: I/Ooperation on closed file.
2. 文件对象的方法
首先假定你已经创建名为wenjian的文件对象。
要读文件内容,请调用wenjian.read(size), 它会读取一些数据并将其作为字符串(在文本模式下)或字节对象(在二进制模式下)返回。 size 是一个可选的数字参数。当 size 被省略或者为负的时候,将读取并返回文件的整个内容;如果文件的大小是机器内存的两倍,那么就可能出现问题。否则,最多读取并返回 size 字节的内容,如果已到达文件末尾,f.read() 将返回一个空字符串 ('')。
f.readline() 从文件中读取一行;换行符(\n)留在字符串的末尾,如果文件不以换行符结尾,则在文件的最后一行省略。这使得返回值明确无误;如果 f.readline() 返回一个空的字符串,则表示已经到达了文件末尾,而空行使用 '\n' 表示,该字符串只包含一个换行符。:
要从文件中读取行,你可以循环遍历文件对象。这是内存高效,快速的,并简化代码:
>>> for line in f:
... print(line, end='')
This is the first line of the file.
Second line of the file
如果你想以列表的形式读取文件中的所有行,你也可以使用 list(f) 或 f.readlines()。
但在打印文件时最好不要用readlines,因为它会保存在在内存你,文件过大会出问题,最好用一下方法:
如果我们要取出光标位置可以用.tell():
如果想调整光标位置可以用.seek():
Flush()方法是用来刷新缓冲区的,即将缓冲区的内容直接写入文库
truncate(size)方法用于截断文件,指定可选参数size,则表示截断文件为size个字节。如果没有指定size,则从当前位置起截断;截断后size后面的所有字符串被删除。
在前面学的的是读,写,模式,那有没有读写模式呢,肯定有的了 r+:读写模式。 w+:写读模式
网友评论