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
  • 处理大文件也比较有效率

你可能感兴趣的:(read(),readline(),readlines()区别与用法)