python中read() readline()以及readlines()用法

来源:互联网 发布:鼠标推荐 知乎 编辑:程序博客网 时间:2024/06/05 11:24

http://www.cnblogs.com/qi09/archive/2012/02/10/2344964.html

http://www.ttlsa.com/python/python-read-readline-readlines-write-writelines/

.read()返回全部全部内容的字符串,

.readlines() 返回list,list的每个元素是每一行的字符串

.readline()返回一行的字符串,运行第二次,返回的就是第二行的字符串


【转自:http://www.ibm.com/developerworks/cn/linux/sdk/python/python-5/index.html#N1004E】

我们谈到“文本处理”时,我们通常是指处理的内容。Python 将文本文件的内容读入可以操作的字符串变量非常容易。文件对象提供了三个“读”方法: .read()、.readline() 和 .readlines()。每种方法可以接受一个变量以限制每次读取的数据量,但它们通常不使用变量。 .read() 每次读取整个文件,它通常用于将文件内容放到一个字符串变量中。然而 .read() 生成文件内容最直接的字符串表示,但对于连续的面向行的处理,它却是不必要的,并且如果文件大于可用内存,则不可能实现这种处理。

.readline() 和 .readlines() 非常相似。它们都在类似于以下的结构中使用:


Python .readlines() 示例

        fh = open('c:\\autoexec.bat')         for  line in  fh.readlines():          print  line       

 

.readline() 和 .readlines() 之间的差异是后者一次读取整个文件,象 .read() 一样。.readlines() 自动将文件内容分析成一个行的列表,该列表可以由 Python 的 for ... in ... 结构进行处理。另一方面,.readline() 每次只读取一行,通常比 .readlines() 慢得多。仅当没有足够内存可以一次读取整个文件时,才应该使用 .readline()。



open()成功执行后返回一个文件对象,以后所有对该文件的操作都可以通过这个“句柄”来进行,现在主要讨论下常用的输入以及输出操作。

输出:

read()方法用于直接读取字节到字符串中,可以接参数给定最多读取的字节数,如果没有给定,则文件读取到末尾。

readline()方法读取打开文件的一行(读取下个行结束符之前的所有字节),然后整行,包括行结束符,作为字符串返回。

readlines()方法读取所有行然后把它们作为一个字符串列表返回

eg:

文件/root/2.txt的内容如下,分别使用上面的三个方法来读取,注意区别:

read():

cat /root/2.txt

I'll write this message for you
hehe,that's will be ok.

>>>>fobj = open('/root/2.txt')    ##默认已只读方式打开

>>>>a = fobj.read()

>>>>a

"I'll write this message for you\nhehe,that's will be ok.\n"   ##直接读取字节到字符串中,包括了换行符

>>>> print a

I'll write this message for you
hehe,that's will be ok.

 

>>>>fobj.close()    ##关闭打开的文件

readline():

>>>> fobj = open('/root/2.txt')

>>>>b  = fobj.readline()

>>>>b

"I'll write this message for you\n"    ##整行,包括行结束符,作为字符串返回

>>>>c = fobj.readline()

c

>>>>"hehe,that's will be ok.\n"      ##整行,包括行结束符,作为字符串返回

>>>>fobj.close()

readlines():

>>>>fobj = open('/root/2.txt')

>>>> d = fobj.readlines()

>>>>d

["I'll write this message for you\n", "hehe,that's will be ok.\n"]    ##读取所有行然后把它们作为一个字符串列表返回

>>>>fobj.close()

输入:

write()方法和read()、readline()方法相反,将字符串写入到文件中。

和readlines()方法一样,writelines()方法是针对列表的操作。它接收一个字符串列表作为参数,将他们写入到文件中,换行符不会自动的加入,因此,需要显式的加入换行符。

eg:

write():

>>> >fobj = open('/root/3.txt','w')      ###确保/root/3.txt没有存在,如果存在,则会首先清空,然后写入。
>>> >msg = ['write date','to 3.txt','finish']    ###这里没有显式的给出换行符
>>> >for m in msg:
...            fobj.write(m)
...
>>> >fobj.close()

cat /root/3.txt

write dateto 3.txtfinish

>>>>fobj = open('/root/3.txt','w')    ###覆盖之前的数据

>>>>msg = ['write date\n','to 3.txt\n','finish\n']     ###显式给出换行符

>>> >for m in msg:
...            fobj.write(m)
...
>>> >fobj.close()

cat /root/3.txt

write date
to 3.txt
finish

writelines():

>>>>fobj = open('/root/3.txt','w')

>>>>msg = ['write date\n','to 3.txt\n','finish\n']

>>>>fobj.writelines(msg)

>>>>fobj.close()

cat /root/3.txt

write date
to 3.txt
finish






阅读全文
0 0
原创粉丝点击