Python文件讀寫(xiě)w+和r+區(qū)別解析
其實(shí)r 是只讀,只能讀不能寫(xiě),這是很明確的,但是r+是可讀寫(xiě),變成r+后還沒(méi)太明白到底加了什么,還是照樣寫(xiě)不了,有沒(méi)有這樣的體驗(yàn)?zāi)?如下代碼,只讀時(shí)
f = open("test.txt", 'r', encoding="utf-8") # 文件句柄
f.write("we are heros\n")
data = f.read()
print(data, type(data))
f.close()
這樣的話報(bào)錯(cuò)是明顯的:io.UnsupportedOperation: not writable,不可寫(xiě)應(yīng)都能理解,但是變成r+呢
f = open("test.txt", 'r+', encoding="utf-8") # 文件句柄
f.write("we are heros\n")
data = f.read()
print(data, type(data))
f.close()
你試過(guò)會(huì)發(fā)現(xiàn),什么也沒(méi)打印出來(lái),同時(shí)注意?。?!也沒(méi)有報(bào)錯(cuò)。到底是什么意思呢?
其實(shí)是由于讀寫(xiě)機(jī)制的問(wèn)題,當(dāng)一個(gè)文件被讀或者寫(xiě)一次后,文件中類(lèi)指針的東西指向的是整個(gè)文件的末尾,再次讀時(shí)從末尾開(kāi)始讀的話肯定是什么都
讀不到了,所以會(huì)出現(xiàn)這樣的問(wèn)題,和連續(xù)f.read()兩次的話,第二次什么都不會(huì)讀到的原因是相同的。那如何寫(xiě)完了接著讀呢,見(jiàn)代碼
f = open("test.txt", 'r+', encoding="utf-8") # 文件句柄
f.write("we are heros\n")
f.seek(0)
data = f.read()
print(data, type(data))
f.close()
加上f.seek(0)使得類(lèi)指針的東西回到文件的開(kāi)頭然后從頭開(kāi)始讀即可。配合f.tell()使用,英文及字符返回的是那個(gè)類(lèi)指針的位置(也就是字符個(gè)數(shù)),但是中文的話是字符 個(gè)數(shù)*3,具體原因還得請(qǐng)大俠給講講。
r+與w+啥區(qū)別呢,不能簡(jiǎn)單的理解為讀寫(xiě)都可,細(xì)節(jié)之處略有不同!
- r+:先讀后寫(xiě)的話是在原有文本后添加, 因?yàn)樽x完后類(lèi)指針已經(jīng)在最末尾了,如果是先寫(xiě)后讀的話,是從頭開(kāi)始覆蓋式寫(xiě)(如只修改了前面的字符,后面字符是不會(huì)被刪掉的),類(lèi)指針停留在寫(xiě)完的末尾,不是文檔末尾,可以讀出未被覆蓋寫(xiě)的部分;
- w+:為先寫(xiě)后讀,先寫(xiě)完后使用f.seek(0)回到初始位置然后開(kāi)始讀,如果先讀的話是讀不出任何東西的,因?yàn)閣+也是純粹的覆蓋寫(xiě),在未使用寫(xiě)操作前文檔是完全空白的,無(wú)論之前該文件里有什么。so ,只能先寫(xiě)后讀。
- r和w的區(qū)別,r必須已經(jīng)存在這個(gè)文件了而 w時(shí)文件可以有也可以沒(méi)有,if有被覆蓋,else沒(méi)有則創(chuàng)建一個(gè)(慎用),r+的寫(xiě)也是覆蓋的!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python實(shí)現(xiàn)批量設(shè)置圖片背景為透明
我們?nèi)粘I钪兄谱鱌PT等教學(xué)資源時(shí),需要批量去除圖片背景,就可以使用 Python 的 rembg 庫(kù),下面我們就來(lái)看看如何操作rembg實(shí)現(xiàn)批量設(shè)置圖片背景為透明吧2024-11-11
Python中的偏函數(shù)及其廣泛應(yīng)用方式
這篇文章主要介紹了Python中的偏函數(shù)及其廣泛應(yīng)用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
python+Matplotlib?繪制帶置信區(qū)間的折線圖
這篇文章主要介紹了python繪制帶置信區(qū)間的折線圖,在本文中,我們將使用?numpy?模塊生成隨機(jī)數(shù)據(jù),并使用?matplotlib?庫(kù)實(shí)現(xiàn)數(shù)據(jù)可視化,需要的朋友可以參考下2023-05-05
Python按行讀取文件的實(shí)現(xiàn)方法【小文件和大文件讀取】
這篇文章主要介紹了Python按行讀取文件的實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了針對(duì)小文件和大文件的讀取方法,需要的朋友可以參考下2016-09-09

