Python中read()、readline()和readlines()三者間的區(qū)別和用法
前言
眾所周知在python中讀取文件常用的三種方法:read(),readline(),readlines(),今天看項目是又忘記他們的區(qū)別了。以前看書的時候覺得這東西很簡單,一眼掃過,待到用時卻也只知道有這么幾個方法,不懂得它的原理與用法。也許吧,沒有永遠的記憶,況且根本沒有用心去記它。話不多說,來一起看看詳細的介紹:
準備
假設a.txt的內(nèi)容如下所示:
Hello Welcome What is the fuck...
一、read([size])方法
read([size])方法從文件當前位置起讀取size個字節(jié),若無參數(shù)size,則表示讀取至文件結束為止,它范圍為字符串對象
f = open("a.txt")
lines = f.read()
print lines
print(type(lines))
f.close()
輸出結果:
Hello Welcome What is the fuck... <type 'str'> #字符串類型
二、readline()方法
從字面意思可以看出,該方法每次讀出一行內(nèi)容,所以,讀取時占用內(nèi)存小,比較適合大文件,該方法返回一個字符串對象。
f = open("a.txt")
line = f.readline()
print(type(line))
while line:
print line,
line = f.readline()
f.close()
輸出結果:
<type 'str'> Hello Welcome What is the fuck...
三、readlines()方法讀取整個文件所有行,保存在一個列表(list)變量中,每行作為一個元素,但讀取大文件會比較占內(nèi)存。
f = open("a.txt")
lines = f.readlines()
print(type(lines))
for line in lines:
print line,
f.close()
輸出結果:
<type 'list'> Hello Welcome What is the fuck...
四、linecache模塊
當然,有特殊需求還可以用linecache模塊,比如你要輸出某個文件的第n行:
# 輸出第2行 text = linecache.getline(‘a(chǎn).txt',2) print text,
對于大文件效率還可以。
下面是其他網(wǎng)友的補充
"""
1、讀取文件的三個方法:read()、readline()、readlines()
2、三個方法均可接受一個變量用以限制每次讀取的數(shù)據(jù)量,通常不使用該變量。
"""
"""
關于read()方法:
1、讀取整個文件,將文件內(nèi)容放到一個字符串變量中
2、如果文件大于可用內(nèi)存,不可能使用這種處理
"""
file_object = open("test.py",'r') #創(chuàng)建一個文件對象,也是一個可迭代對象
try:
all_the_text = file_object.read() #結果為str類型
print type(all_the_text)
print "all_the_text=",all_the_text
finally:
file_object.close()
"""
關于readline()方法:
1、readline()每次讀取一行,比readlines()慢得多
2、readline()返回的是一個字符串對象,保存當前行的內(nèi)容
"""
file_object1 = open("test.py",'r')
try:
while True:
line = file_object1.readline()
if line:
print "line=",line
else:
break
finally:
file_object1.close()
"""
關于readlines()方法:
1、一次性讀取整個文件。
2、自動將文件內(nèi)容分析成一個行的列表。
"""
file_object2 = open("test.py",'r')
try:
lines = file_object2.readlines()
print "type(lines)=",type(lines) #type(lines)= <type 'list'>
for line in lines:
print "line=",line
finally:
file_object2.close()
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持
相關文章
Pytorch基本變量類型FloatTensor與Variable用法
今天小編就為大家分享一篇Pytorch基本變量類型FloatTensor與Variable用法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01
Django ORM實現(xiàn)按天獲取數(shù)據(jù)去重求和例子
這篇文章主要介紹了Django ORM實現(xiàn)按天獲取數(shù)據(jù)去重求和例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05
對Python中實現(xiàn)兩個數(shù)的值交換的集中方法詳解
今天小編就為大家分享一篇對Python中實現(xiàn)兩個數(shù)的值交換的集中方法詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01
PyG搭建GCN模型實現(xiàn)節(jié)點分類GCNConv參數(shù)詳解
這篇文章主要為大家介紹了PyG搭建GCN模型實現(xiàn)節(jié)點分類GCNConv參數(shù)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05
python下setuptools的安裝詳解及No module named setuptools的解決方法
這篇文章主要給大家介紹了關于python下setuptools的安裝以及No module named setuptools問題的解決方法,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。2017-07-07
tensorflow入門:TFRecordDataset變長數(shù)據(jù)的batch讀取詳解
今天小編就為大家分享一篇tensorflow入門:TFRecordDataset變長數(shù)據(jù)的batch讀取詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01
利用Python腳本生成sitemap.xml的實現(xiàn)方法
最近項目中需要用腳本生成sitemap,中間學習了一下sitemap的格式和lxml庫的用法。把結果記錄一下,方便以后需要直接拿來用。下面這篇文章主要介紹了利用Python腳本生成sitemap.xml的實現(xiàn)方法,需要的朋友可以參考借鑒,一起來看看吧。2017-01-01

