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