Python文件操作中的a,a+,w,w+,rb+,rw+,ra+几种方式的区别
access_mode:打開方式,r讀,w寫,a追加,r+ w+ a+ 都是以讀寫方式打開,rb二進制讀,wb二進制寫,rb+ wb+ ab+二進制讀寫?
buffering:默認值?
二、對文件進行操作?
將文件中的內(nèi)容讀入到一個字符串變量/列表中?
函數(shù):read(),readline(),readlines(),write(),writelines()?
1、read() 讀取整個文件到字符串變量中?
2、readline() 讀取文件中的一行,然后返回整行,包括行結(jié)束符到字符串變量中?
3、readlines() 讀取整個文件,返回一個字符串列表,列表中的每個元素都是一個字符串,代表一行
第一步 排除文件打開方式錯誤:
r?只讀,r+?讀寫,不創(chuàng)建
w新建只寫,w+新建讀寫,二者都會將文件內(nèi)容清零
(以w方式打開,不能讀出。w+可讀寫)
w+與r+區(qū)別:
r+:可讀可寫,若文件不存在,報錯;w+: 可讀可寫,若文件不存在,創(chuàng)建
r+與a+區(qū)別:
fd = open("1.txt",'w+')
fd.write('123')
fd = open("1.txt",'r+')
fd.write('456')
fd = open("1.txt",'a+')
fd.write('789')
結(jié)果:456789
說明r+進行了覆蓋寫。
以a,a+的方式打開文件,附加方式打開
(a:附加寫方式打開,不可讀;a+:?附加讀寫方式打開)
以 'U' 標志打開文件, 所有的行分割符通過 Python 的輸入方法(例#如 read*() ),返回時都會被替換為換行符\n. ('rU' 模式也支持 'rb' 選項) .?
r和U要求文件必須存在
不可讀的打開方式:w和a
若不存在會創(chuàng)建新文件的打開方式:a,a+,w,w+
>>> fd=open(r'f:\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(r'f:\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.正確讀寫方式打開,出現(xiàn)亂碼
>>> fd=open(r'f:\mypython\test.py','a+')
>>> fd.write('123')
>>> fd.read()
>>> fd.close()
close之前,手動打開文件,什么都沒寫入;close后,手動打開文件,亂碼:123嚅? ? ??
原因分析:指針問題。open()以a+模式開啟了一個附加讀寫模式的文件,由于是a,所以指針在文件末尾。此時如果做read(),則Python發(fā)現(xiàn)指針位置就是EOF,讀取到空字符串。
在寫入123之后,指針的位置是4,仍然是文件尾,文件在內(nèi)存中是123[EOF]。
但看起來read()的時候,Python仍然去試圖在磁盤的文件上,將指針從文件頭向后跳3,再去讀取到EOF為止。
也就是說,你實際上是跳過了該文件真正的EOF,為硬盤底層的數(shù)據(jù)做了一個dump,一直dump到了一個從前存盤文件的[EOF]為止。所以最后得到了一些根本不期待的隨機亂字符,而不是編碼問題造成的亂碼。
解決方案:讀取之前將指針重置為文件頭(如果讀取之后重置再讀,無效)
>>> fd=open(r'f:\mypython\test.py','a+')
>>> fd.seek(0)
>>> fd.read()
'123'<span style="white-space:pre"> </span>#順利讀出</span></span>
3.文件里有內(nèi)容,卻讀出空字符
>>> fd=open(r'f:\mypython\test.py','w+') #清空內(nèi)容,重新寫入
>>> fd.write('456')
>>> fd.flush()<span style="white-space:pre"> </span>#確定寫入,此時文件內(nèi)容為“456”
>>> fd.read()
'' #讀出空
原因:同樣是指針問題,寫入后指針指向末尾[EOF],因此讀出空
解決方案一、調(diào)用close后重新打開,指針位于開頭。(r,r+,a+,U都可以,注意不要用w,w+,a打開)
>>> fd.close()
>>> fd=open(r'f:\mypython\test.py','a+')
>>> fd.read()
'456'
>>> fd.close()
>>> fd=open(r'f:\mypython\test.py','r+')
>>> fd.read()
'456'<pre name="code" class="python">>>> fd.close()
>>> fd=open(r'f:\mypython\test.py','r')
>>> fd.read()
'456'
>>> fd.close()
>>> fd=open(r'f:\mypython\test.py','U')
>>> fd.read()
'456'
解決方案二、調(diào)用seek指向開頭
>>> fd=open(r'f:\mypython\test.py','w+')
>>> fd.write('456')
>>> fd.seek(0)
>>> fd.read()
'456'
seek函數(shù)
? ? seek(offset[, whence]) ,offset是相對于某個位置的偏移量。位置由whence決定,默認whence=0,從開頭起;whence=1,從當前位置算起;whence=2相對于文件末尾移動,通常offset取負值。
4. 記得close()關(guān)閉
當我們寫文件時,操作系統(tǒng)往往不會立刻把數(shù)據(jù)寫入磁盤,而是放到內(nèi)存緩存起來,空閑的時候再慢慢寫入。只有調(diào)用close()方法時,操作系統(tǒng)才保證把沒有寫入的數(shù)據(jù)全部寫入磁盤。忘記調(diào)用close()的后果是數(shù)據(jù)可能只寫了一部分到磁盤,剩下的丟失了。所以,還是用with語句來得保險:
with open('/Users/michael/test.txt', 'w') as f:
? ? f.write('Hello, world!')
總結(jié)
以上是生活随笔為你收集整理的Python文件操作中的a,a+,w,w+,rb+,rw+,ra+几种方式的区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Python】from __futur
- 下一篇: websocket python爬虫_p