Python中read(),readline(),readlines()区别与用法
整理一下python3里面关于read、readline、readlines的方法,有关文件打开模式的内容可以参见我之前的文章
文件 runoob.txt 的内容如下:
1:www.runoob.com
2:www.runoob.com
3:www.runoob.com
4:www.runoob.com
5:www.runoob.com
1. read方法
概述
read() 方法用于从文件读取指定的字节数,如果未给定或为负则读取所有。
语法
read() 方法语法如下:
fileObject.read();
参数
size -- 从文件中读取的字节数。若无size参数则默认读取全部
返回值
返回从字符串中读取的字节。
实例
#!/usr/bin/python
# -*- coding: UTF-8 -*-
打开文件
fo = open(“runoob.txt”, “rw+”)
print “文件名为: “, fo.name
line = fo.read(10)
print “读取的字符串: %s” % (line)
关闭文件
fo.close()
#输出
文件名为: runoob.txt
读取的字符串: 1:www.runo
2. readline
概述
readline() 方法用于从文件读取整行,包括 "\n" 字符。如果指定了一个非负数的参数,则返回指定大小的字节数,包括 "\n" 字符。因为每次仅读取一行,所以读取时占用内存小,比较适合大文件,该方法返回一个字符串对象。
语法
readline() 方法语法如下:
fileObject.readline();
参数
size -- 从文件中读取的字节数。
返回值
返回从字符串中读取的字节。
实例
#!/usr/bin/python
# -*- coding: UTF-8 -*-
打开文件
fo = open(“runoob.txt”, “rw+”)
print “文件名为: “, fo.name
line = fo.readline()
print “读取第一行 %s” % (line)
line = fo.readline(5)
print “读取的字符串为: %s” % (line)
关闭文件
fo.close()
#输出
文件名为: runoob.txt
读取第一行 1:www.runoob.com
读取的字符串为: 2:www
3. readlines
概述
readlines() 方法用于读取所有行(直到结束符 EOF)并返回列表,每行作为一个元素,该列表可以由 Python 的 for... in ... 结构进行处理。但读取大文件会比较占内存。
- 如果碰到结束符 EOF 则返回空字符串。
语法
readlines() 方法语法如下:
fileObject.readlines( );
参数
无。
返回值
返回列表,包含所有的行。
实例
#!/usr/bin/python
# -*- coding: UTF-8 -*-
# 打开文件
fo = open("runoob.txt", "r")
print "文件名为: ", fo.name
for line in fo.readlines(): #依次读取每行
line = line.strip() #去掉每行头尾空白
print "读取的数据为: %s" % (line)
# 关闭文件
fo.close()
#输出
文件名为: runoob.txt
读取的数据为: 1:www.runoob.com
读取的数据为: 2:www.runoob.com
读取的数据为: 3:www.runoob.com
读取的数据为: 4:www.runoob.com
读取的数据为: 5:www.runoob.com
4. linecache模块
当然,有特殊需求还可以用linecache模块,比如你要输出某个文件的第n行:
# 输出第2行
text = linecache.getline(‘a.txt’,2)
print text
- 处理大文件也比较有效率