假设a.txt的内容如下所示:
1 Hello 2 Welcome 3 What is the fuck...
read:读取整个文件。
read([size])
方法从文件当前位置起读取size个字节,若无参数size,则表示读取至文件结束为止,它范围为字符串对象
1 f = open("a.txt") 2 lines = f.read() 3 print lines 4 print(type(lines)) 5 f.close()
输出结果:
1 Hello 2 Welcome 3 What is the fuck... 4 <type 'str'> #字符串类型
readline:读取下一行,使用生成器方法。
从字面意思可以看出,该方法每次读出一行内容,所以,读取时占用内存小,比较适合大文件,该方法返回一个字符串对象。
1 def pyReadLine(filename): 2 file_object1 = open('a.txt','r') 3 try: 4 while True: 5 line = file_object1.readline() 6 if line: 7 print ("line=",line) 8 else: 9 break 10 finally: 11 file_object1.close()
输出结果:
1 <type 'str'> 2 Hello 3 Welcome 4 What is the fuck...
readlines:读取整个文件到一个迭代器以供我们遍历。
readlines()方法读取整个文件所有行,保存在一个列表(list)变量中,每行作为一个元素,但读取大文件会比较占内存。
1 f = open("a.txt") 2 lines = f.readlines() 3 print(type(lines)) 4 for line in lines: 5 print line, 6 f.close()
输出结果:
1 <type 'list'> 2 Hello 3 Welcome 4 What is the fuck...