Python逐行读取文件内容
生活随笔
收集整理的這篇文章主要介紹了
Python逐行读取文件内容
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
也可以寫成以下更簡潔的形式
for line in open("foo.txt"):print line,更詳細(xì)的文件按行讀取操作可以參考:http://www.cnblogs.com/xuxn/archive/2011/07/27/read-a-file-with-python.html
1. 最基本的讀文件方法: ? # File: readline-example-1.py file = open("sample.txt")while 1:line = file.readline()if not line:breakpass # do something 一行一行得從文件讀數(shù)據(jù),顯然比較慢;不過很省內(nèi)存。在我的機器上讀10M的sample.txt文件,每秒大約讀32000行 2. 用fileinput模塊 ? # File: readline-example-2.py import fileinputfor line in fileinput.input("sample.txt"):pass寫法簡單一些,不過測試以后發(fā)現(xiàn)每秒只能讀13000行數(shù)據(jù),效率比上一種方法慢了兩倍多…… 3. 帶緩存的文件讀取 ? # File: readline-example-3.py file = open("sample.txt")while 1:lines = file.readlines(100000)if not lines:breakfor line in lines:pass # do something 這個方法真的更好嗎?事實證明,用同樣的數(shù)據(jù)測試,它每秒可以讀96900行數(shù)據(jù)!效率是第一種方法的3倍,第二種方法的7倍! ————————————————————————————————————————————————————————————在Python 2.2以后,我們可以直接對一個file對象使用for循環(huán)讀每行數(shù)據(jù): ? # File: readline-example-5.py file = open("sample.txt")for line in file:pass # do something 而在Python 2.1里,你只能用xreadlines迭代器來實現(xiàn): ? # File: readline-example-4.py file = open("sample.txt")for line in file.xreadlines():pass # do something 翻譯自:http://hi.baidu.com/netspider_2007/blog/item/870354c753e4a71c9c163d64.html總結(jié)
以上是生活随笔為你收集整理的Python逐行读取文件内容的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python的while和for循环
- 下一篇: Python中map()函数浅析