Python中文件讀寫之 w+ 與 r+ 到底有啥區別?


其實r 是只讀,只能讀不能寫,這是很明確的,但是r+是可讀寫,變成r+后還沒太明白到底加了什么,還是照樣寫不了,有沒有這樣的體驗呢,如下代碼,只讀時

f = open("test.txt", 'r', encoding="utf-8")  # 文件句柄
f.write("we are heros\n")

data = f.read()
print(data, type(data))
f.close()

這樣的話報錯是明顯的:io.UnsupportedOperation: not writable,不可寫應都能理解,但是變成r+呢

f = open("test.txt", 'r+', encoding="utf-8")  # 文件句柄
f.write("we are heros\n") data = f.read() print(data, type(data)) f.close()

你試過會發現,什么也沒打印出來,同時注意!!!也沒有報錯。到底是什么意思呢?

其實是由於讀寫機制的問題,當一個文件被讀或者寫一次后,文件中類指針的東西指向的是整個文件的末尾,再次讀時從末尾開始讀的話肯定是什么都

讀不到了,所以會出現這樣的問題,和連續f.read()兩次的話,第二次什么都不會讀到的原因是相同的。那如何寫完了接着讀呢,見代碼

1 f = open("test.txt", 'r+', encoding="utf-8")  # 文件句柄
2 f.write("we are heros\n") 3 f.seek(0) 4 data = f.read() 5 print(data, type(data)) 6 f.close()

加上f.seek(0)使得類指針的東西回到文件的開頭然后從頭開始讀即可。配合f.tell()使用,英文及字符返回的是那個類指針的位置(也就是字符個數),但是中文的話是字符 個數*3,具體原因還得請大俠給講講。

r+與w+啥區別呢,不能簡單的理解為讀寫都可,細節之處略有不同!

r+:先讀后寫的話是在原有文本后添加, 因為讀完后類指針已經在最末尾了,如果是先寫后讀的話,是從頭開始覆蓋式寫(如只修改了前面的字符,后面字符是不會被刪掉的),類指針停留在寫完的末尾,不是文檔末尾,可以讀出未被覆蓋寫的部分;

w+:為先寫后讀,先寫完后使用f.seek(0)回到初始位置然后開始讀,如果先讀的話是讀不出任何東西的,因為w+也是純粹的覆蓋寫,在未使用寫操作前文檔是完全空白的,無論之前該文件里有什么。so ,只能先寫后讀。

r和w的區別,r必須已經存在這個文件了而 w時文件可以有也可以沒有,if有被覆蓋,else沒有則創建一個(慎用),r+的寫也是覆蓋的!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM