1. 程式人生 > >Python文件打開方式詳解——r,w,a,r+,w+,a+

Python文件打開方式詳解——r,w,a,r+,w+,a+

bsp 默認 字符串 文件 關閉 table 偏移量 tro border

r,r+,w,w+,a,a+作用

r 只讀 不創建
r+ 讀寫

w  新建只寫 二者都會將文件清空
w+ 新建讀寫


a 附加方式打開,不可讀
a+ 附加讀寫方式打開


w+與r+區別:

r+ 可讀可寫,若文件不存在,報錯
w+ 可讀可寫,若文件不存在,創建

r+與a+區別:

fd = open("1.txt",w+)  
fd.write(123)  
fd = open("1.txt",r+)  
fd.write(456)  
fd = open("1.txt",a+)  
fd.write(
789)

結果:456789

說明r+進行了覆蓋寫。

以a,a+的方式打開文件,附加方式打開

(a:附加寫方式打開,不可讀;a+: 附加讀寫方式打開)

以 ‘U‘ 標誌打開文件, 所有的行分割符通過 Python 的輸入方法(例#如 read*() ),返回時都會被替換為換行符\n. (‘rU‘ 模式也支持 ‘rb‘ 選項) .

r和U要求文件必須存在

不可讀的打開方式:w和a

若不存在會創建新文件的打開方式:a,a+,w,w+

>>> fd=open(rf:\mypython\test.py,w)    #只寫方式打開,讀取報錯  
>>> fd.read()  
Traceback (most recent call last):  
  File 
"<stdin>", line 1, in <module> IOError: File not open for reading >>> fd=open(rf:\mypython\test.py,a)#附加寫方式打開,讀取報錯 >>> fd.read() Traceback (most recent call last): File "<stdin>", line 1, in <module> IOError: File not open for reading >>></span></span></span>

2.正確讀寫方式打開,出現亂碼

>>> fd=open(rf:\mypython\test.py,a+)  
>>> fd.write(123)  
>>> fd.read()  
>>> fd.close()  

close之前,手動打開文件,什麽都沒寫入;close後,手動打開文件,亂碼:123嚅?

原因分析:指針問題。open()以a+模式開啟了一個附加讀寫模式的文件,由於是a,所以指針在文件末尾。此時如果做read(),則Python發現指針位置就是EOF,讀取到空字符串。

在寫入123之後,指針的位置是4,仍然是文件尾,文件在內存中是123[EOF]。

但看起來read()的時候,Python仍然去試圖在磁盤的文件上,將指針從文件頭向後跳3,再去讀取到EOF為止。

也就是說,你實際上是跳過了該文件真正的EOF,為硬盤底層的數據做了一個dump,一直dump到了一個從前存盤文件的[EOF]為止。所以最後得到了一些根本不期待的隨機亂字符,而不是編碼問題造成的亂碼。

解決方案:讀取之前將指針重置為文件頭(如果讀取之後重置再讀,無效)

>>> fd=open(rf:\mypython\test.py,a+)  
>>> fd.seek(0)  
>>> fd.read()  
123<span style="white-space:pre">           </span>#順利讀出</span></span> 

原因:同樣是指針問題,寫入後指針指向末尾[EOF],因此讀出空

解決方案一、調用close後重新打開,指針位於開頭。(r,r+,a+,U都可以,註意不要用w,w+,a打開)

>>> fd.close()  
>>> fd=open(rf:\mypython\test.py,a+)  
>>> fd.read()  
456  
>>> fd.close()  
>>> fd=open(rf:\mypython\test.py,r+)  
>>> fd.read()  
456<pre name="code" class="python">>>> fd.close()  
>>> fd=open(rf:\mypython\test.py,r)  
>>> fd.read()  
456  
>>> fd.close()  
>>> fd=open(rf:\mypython\test.py,U)  
>>> fd.read()  
456  

解決方案二、調用seek指向開頭

>>> fd=open(rf:\mypython\test.py,w+)  #w+會先清空文件所以需要重寫內容
>>> fd.write(456)  
>>> fd.seek(0)  
>>> fd.read()  
456  

seek函數

seek(offset[, whence]) ,offset是相對於某個位置的偏移量。位置由whence決定,默認whence=0,從開頭起;whence=1,從當前位置算起;whence=2相對於文件末尾移動,通常offset取負值。

4. 記得close()關閉

當我們寫文件時,操作系統往往不會立刻把數據寫入磁盤,而是放到內存緩存起來,空閑的時候再慢慢寫入。只有調用close()方法時,操作系統才保證把沒有寫入的數據全部寫入磁盤。忘記調用close()的後果是數據可能只寫了一部分到磁盤,剩下的丟失了。所以,還是用with語句來得保險:

with open(/Users/michael/test.txt, w) as f:
    f.write(Hello, world!)

 with open(log,r,encoding=utf8) as f:
    f.readlines()
    f.read()

#py2.7以後with增加方法,with同時管理多個文件對象
with open(log1,r,encoding=utf8) as f_read,open(log2,w,encoding=utf8) as f_write:
     for line in f_read:
         f_write.write(line)

參考:

https://blog.csdn.net/ztf312/article/details/47259805

Python文件打開方式詳解——r,w,a,r+,w+,a+