欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python文件讀寫w+和r+區(qū)別解析

 更新時(shí)間:2020年03月26日 11:47:15   作者:Python熱愛者  
這篇文章主要介紹了Python文件讀寫w+和r+區(qū)別解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

其實(shí)r 是只讀,只能讀不能寫,這是很明確的,但是r+是可讀寫,變成r+后還沒太明白到底加了什么,還是照樣寫不了,有沒有這樣的體驗(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,不可寫應(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()

你試過會(huì)發(fā)現(xiàn),什么也沒打印出來,同時(shí)注意?。?!也沒有報(bào)錯(cuò)。到底是什么意思呢?

其實(shí)是由于讀寫機(jī)制的問題,當(dāng)一個(gè)文件被讀或者寫一次后,文件中類指針的東西指向的是整個(gè)文件的末尾,再次讀時(shí)從末尾開始讀的話肯定是什么都

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

 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)使得類指針的東西回到文件的開頭然后從頭開始讀即可。配合f.tell()使用,英文及字符返回的是那個(gè)類指針的位置(也就是字符個(gè)數(shù)),但是中文的話是字符 個(gè)數(shù)*3,具體原因還得請(qǐng)大俠給講講。

r+與w+啥區(qū)別呢,不能簡單的理解為讀寫都可,細(xì)節(jié)之處略有不同!

  • r+:先讀后寫的話是在原有文本后添加, 因?yàn)樽x完后類指針已經(jīng)在最末尾了,如果是先寫后讀的話,是從頭開始覆蓋式寫(如只修改了前面的字符,后面字符是不會(huì)被刪掉的),類指針停留在寫完的末尾,不是文檔末尾,可以讀出未被覆蓋寫的部分;
  • w+:為先寫后讀,先寫完后使用f.seek(0)回到初始位置然后開始讀,如果先讀的話是讀不出任何東西的,因?yàn)閣+也是純粹的覆蓋寫,在未使用寫操作前文檔是完全空白的,無論之前該文件里有什么。so ,只能先寫后讀。
  • r和w的區(qū)別,r必須已經(jīng)存在這個(gè)文件了而 w時(shí)文件可以有也可以沒有,if有被覆蓋,else沒有則創(chuàng)建一個(gè)(慎用),r+的寫也是覆蓋的!

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論