python?使用?with?open()?as?讀寫(xiě)文件的操作方法
讀文件:
要以讀文件的模式打開(kāi)一個(gè)文件對(duì)象,使用Python內(nèi)置的open()
函數(shù),傳入文件名和標(biāo)示符:
>>> f = open('E:\python\python\test.txt', 'r')
標(biāo)示符'r'表示讀,這樣,我們就成功地打開(kāi)了一個(gè)文件。
如果文件不存在,open()
函數(shù)就會(huì)拋出一個(gè)IOError
的錯(cuò)誤,并且給出錯(cuò)誤碼和詳細(xì)的信息告訴你文件不存在:
f=open('E:\python\python\notfound.txt', 'r') Traceback (most recent call last): File "<stdin>", line 1, in <module> FileNotFoundError: [Errno 2] No such file or directory: 'E:\python\python\notfound.txt'
如果文件打開(kāi)成功,接下來(lái),調(diào)用read()
方法可以一次讀取文件的全部?jī)?nèi)容,Python把內(nèi)容讀到內(nèi)存,用一個(gè)str
對(duì)象表示:
>>> f.read() 'Hello, python!
最后一步是調(diào)用close()
方法關(guān)閉文件。文件使用完畢后必須關(guān)閉,因?yàn)槲募?duì)象會(huì)占用操作系統(tǒng)的資源,并且操作系統(tǒng)同一時(shí)間能打開(kāi)的文件數(shù)量也是有限的:
>>> f.close()
由于文件讀寫(xiě)時(shí)都有可能產(chǎn)生IOError
,一旦出錯(cuò),后面的f.close()
就不會(huì)調(diào)用。所以,為了保證無(wú)論是否出錯(cuò)都能正確地關(guān)閉文件,我們可以使用try ... finally
來(lái)實(shí)現(xiàn):
try: f = open('/path/', 'r') print(f.read()) finally: if f: f.close()
每次都這么寫(xiě)實(shí)在太繁瑣,所以,Python引入了with
語(yǔ)句來(lái)自動(dòng)幫我們調(diào)用close()
方法:
with open('/path/to/file', 'r') as f: print(f.read())
這和前面的try ... finally
是一樣的,但是代碼更佳簡(jiǎn)潔,并且不必調(diào)用f.close()
方法。
調(diào)用read()
會(huì)一次性讀取文件的全部?jī)?nèi)容,如果文件有20G,內(nèi)存就爆了,所以,要保險(xiǎn)起見(jiàn),可以反復(fù)調(diào)用read(size)
方法,每次最多讀取size個(gè)字節(jié)的內(nèi)容。另外,調(diào)用readline()
可以每次讀取一行內(nèi)容,調(diào)用readlines()
一次讀取所有內(nèi)容并按行返回list
。因此,要根據(jù)需要決定怎么調(diào)用。
如果文件很小,read()
一次性讀取最方便;如果不能確定文件大小,反復(fù)調(diào)用read(size)
比較保險(xiǎn);如果是配置文件,調(diào)用readlines()
最方便:
for line in f.readlines(): print(line.strip()) # 把末尾的'\n'刪掉
寫(xiě)文件
寫(xiě)文件和讀文件是一樣的,唯一區(qū)別是調(diào)用open()
函數(shù)時(shí),傳入標(biāo)識(shí)符'w'
或者'wb'
表示寫(xiě)文本文件或?qū)懚M(jìn)制文件:
>>> f = open('E:\python\python\test.txt', 'w') >>> f.write('Hello, python!') >>> f.close()
可以反復(fù)調(diào)用write()
來(lái)寫(xiě)入文件,但是務(wù)必要調(diào)用f.close()
來(lái)關(guān)閉文件。當(dāng)我們寫(xiě)文件時(shí),操作系統(tǒng)往往不會(huì)立刻把數(shù)據(jù)寫(xiě)入磁盤(pán),而是放到內(nèi)存緩存起來(lái),空閑的時(shí)候再慢慢寫(xiě)入。只有調(diào)用close()
方法時(shí),操作系統(tǒng)才保證把沒(méi)有寫(xiě)入的數(shù)據(jù)全部寫(xiě)入磁盤(pán)。忘記調(diào)用close()
的后果是數(shù)據(jù)可能只寫(xiě)了一部分到磁盤(pán),剩下的丟失了。所以,還是用with
語(yǔ)句來(lái)得保險(xiǎn):
with open('E:\python\python\test.txt', 'w') as f: f.write('Hello, python!')
要寫(xiě)入特定編碼的文本文件,請(qǐng)給open()
函數(shù)傳入encoding
參數(shù),將字符串自動(dòng)轉(zhuǎn)換成指定編碼
字符編碼
要讀取非UTF-8編碼的文本文件,需要給open()
函數(shù)傳入encoding
參數(shù),例如,讀取GBK編碼的文件:
>>> f = open('E:\python\python\gbk.txt', 'r', encoding='gbk') >>> f.read() '測(cè)試'
遇到有些編碼不規(guī)范的文件,你可能會(huì)遇到UnicodeDecodeError
,因?yàn)樵谖谋疚募锌赡軍A雜了一些非法編碼的字符。遇到這種情況,open()
函數(shù)還接收一個(gè)errors
參數(shù),表示如果遇到編碼錯(cuò)誤后如何處理。最簡(jiǎn)單的方式是直接忽略:
>>> f = open('E:\python\python\gbk.txt', 'r', encoding='gbk', errors='ignore')
二進(jìn)制文件
前面講的默認(rèn)都是讀取文本文件,并且是UTF-8編碼的文本文件。要讀取二進(jìn)制文件,比如圖片、視頻等等,用'rb'
模式打開(kāi)文件即可:
>>> f = open('E:\python\python\test.jpg', 'rb') >>> f.read() b'\xff\xd8\xff\xe1\x00\x18Exif\x00\x00...' # 十六進(jìn)制表示的字節(jié)
總結(jié):以后讀寫(xiě)文件盡量使用with open語(yǔ)句,少使用f = open()語(yǔ)句
對(duì)于多個(gè)文件的讀寫(xiě),可以寫(xiě)成以下兩種方式:
1、
with open('C:\Desktop\text.txt','r') as f: with open('C:\Desktop\text1.txt','r') as f1: with open('C:\Desktop\text2.txt','r') as f2 ........ ........ ........
2、
with open(''C:\Desktop\text.txt','r') as f: ........ with open(''C:\Desktop\text1.txt','r') as f1: ........ with open('C:\Desktop\text2.txt','r') as f2: ........
文件的讀寫(xiě)方式列表:
File 對(duì)象屬性:
Reference:
https://www.cnblogs.com/ymjyqsx/p/6554817.html
https://www.cnblogs.com/tianyiliang/p/8192703.html
到此這篇關(guān)于python 使用 with open() as 讀寫(xiě)文件的文章就介紹到這了,更多相關(guān)python 文件讀寫(xiě)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python制作的天氣預(yù)報(bào)小工具(gui界面)
大家好??!我用Tkinter寫(xiě)了一個(gè)天氣預(yù)報(bào)小工具,支持34個(gè)省級(jí)行政區(qū)以及港澳臺(tái)地區(qū)天氣,覆蓋全面。程序打包好放在了藍(lán)奏云,與大家分享一下。2021-05-05TensorFlow安裝及jupyter notebook配置方法
下面小編就為大家?guī)?lái)一篇TensorFlow安裝及jupyter notebook配置方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09python 網(wǎng)絡(luò)爬蟲(chóng)初級(jí)實(shí)現(xiàn)代碼
這篇文章主要介紹了python 網(wǎng)絡(luò)爬蟲(chóng)初級(jí)實(shí)現(xiàn)代碼,需要的朋友可以參考下2016-02-02Python數(shù)據(jù)庫(kù)反向生成Model最優(yōu)方案示例
這篇文章主要介紹了Python數(shù)據(jù)庫(kù)反向生成Model最優(yōu)方案的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Python實(shí)現(xiàn)自動(dòng)運(yùn)行代碼的方法詳解
在軟件開(kāi)發(fā)和數(shù)據(jù)科學(xué)領(lǐng)域,自動(dòng)運(yùn)行代碼是提高效率和確保一致性的關(guān)鍵,本文將深入探討如何使用Python實(shí)現(xiàn)自動(dòng)運(yùn)行代碼的各種方法,希望對(duì)大家有所幫助2023-12-12解決PIP安裝第三方庫(kù)報(bào)錯(cuò)SSL: CERTIFICATE_VERIFY_FAILED問(wèn)題
這篇文章主要介紹了解決PIP安裝第三方庫(kù)報(bào)錯(cuò)SSL: CERTIFICATE_VERIFY_FAILED問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01python使用UDP實(shí)現(xiàn)客戶端和服務(wù)器對(duì)話
這篇文章主要為大家介紹了python使用UDP實(shí)現(xiàn)客戶端和服務(wù)器對(duì)話示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03python selenium操作cookie的實(shí)現(xiàn)
這篇文章主要介紹了python selenium操作cookie的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03如何利用python實(shí)現(xiàn)kmeans聚類
K-Means是聚類算法的一種,以距離來(lái)判斷數(shù)據(jù)點(diǎn)間的相似度并對(duì)數(shù)據(jù)進(jìn)行聚類,下面這篇文章主要給大家介紹了關(guān)于如何利用python實(shí)現(xiàn)kmeans聚類的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05