python中的三个读read(),readline()和readlines()

转载 2015年11月17日 23:51:40
我们谈到“文本处理”时,我们通常是指处理的内容。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()。   

写:

writeline()是输出后换行,下次写会在下一行写。write()是输出后光标在行末不会换行,下次写会接着这行写



  1. 通过readline输出,对于比较大的文件,这种占用内存比较小。  
  2. #coding:utf-8  
  3.   
  4. f = open('poem.txt','r')  
  5. result = list()  
  6. for line in open('poem.txt'):  
  7.     line = f.readline()  
  8.     print line  
  9.     result.append(line)  
  10. print result  
  11. f.close()                  
  12. open('result-readline.txt''w').write('%s' % '\n'.join(result))  



  1. #coding:utf-8  
  2. '''''cdays-4-exercise-6.py 文件基本操作 
  3.     @note: 文件读取写入, 列表排序, 字符串操作 
  4.     @see: 字符串各方法可参考hekp(str)或Python在线文档http://docs.python.org/lib/string-methods.html 
  5. '''  
  6.   
  7. f = open('cdays-4-test.txt''r')                   #以读方式打开文件  
  8. result = list()  
  9. for line in f.readlines():                          #依次读取每行  
  10.     line = line.strip()                             #去掉每行头尾空白  
  11.     if not len(line) or line.startswith('#'):       #判断是否是空行或注释行  
  12.         continue                                    #是的话,跳过不处理  
  13.     result.append(line)                             #保存  
  14. result.sort()                                       #排序结果  
  15. print result  
  16. open('cdays-4-result.txt''w').write('%s' % '\n'.join(result)) #保存入结果文件  

相关文章推荐

struts2与urlrewrite的整合

struts2与urlrewrite的整合

用python进行数据预处理,过滤特殊符号,英文和数字。(适用于中文分词)

要进行中文分词,必须要求数据格式全部都是中文,需求过滤掉特殊符号、标点、英文、数字等。当然了用户可以根据自己的要求过滤自定义字符。 实验环境:python、mysql实验目的:从数据库读取数据,过滤...

Python文本处理之按行处理大文件

以行的形式读出一个文件最简单的方式是使用文件对象的readline()、readlines()和xreadlines()方法。 Python2.2+为这种频繁的操作提供了一个简化的语法——让文件对象...

python中的三个读read(),readline()和readlines()

我们谈到“文本处理”时,我们通常是指处理的内容。Python 将文本文件的内容读入可以操作的字符串变量非常容易。文件对象提供了三个“读”方法: .read()、.readline() 和 .readl...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)