zoukankan      html  css  js  c++  java
  • python中的三个读read(),readline()和readlines()

    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有两行

    a
    b

    line1=file1.read()  输出结果为“文件的全部文本”

    a
    b

    line1=file1.readline()   输出结果为“文件的首行”

    a

    line1=file1.readlines() 输出结果为“所有文件行程一行,类似list列表的形式”

      ['a ', 'b']

    ==================================================================

    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' % ' '.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' % ' '.join(result)) #保存入结果文件  
  • 相关阅读:
    Mac OS X各版本号的历史费用和升级关系
    Openlayers2中统计图的实现
    CentOS下Redisserver安装配置
    最小生成树算法
    机器学习---支持向量机(SVM)
    Android HttpURLConnection源代码分析
    Lighttpd1.4.20源代码分析 笔记 状态机之错误处理和连接关闭
    <html>
    【LeetCode-面试算法经典-Java实现】【059-Spiral Matrix II(螺旋矩阵II)】
    软件开发中的11个系统思维定律
  • 原文地址:https://www.cnblogs.com/monsteryang/p/6442257.html
Copyright © 2011-2022 走看看