第一步 排除檔案開啟方式錯誤:
r唯讀,r+讀寫,不建立
w新建只寫,w+新建讀寫
,二者都
會將檔案
內容清零
(以w方式開啟,不能讀出。w+可讀寫)
w+與r+區別:
r+:可讀可寫,若檔案不存在,報錯;w+: 可讀可寫,若檔案不存在,建立
r+與a+區別:
[python]
view plain
copy
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+
[python]
view plain
copy
>>> fd=open(r
'f:\mypython\test.py'
,'w'
)
#唯讀方式開啟,讀取報錯
>>> fd.read()
traceback (most recent call last):
file ""
, line 1,
inioerror: file not
open
forreading
>>> fd=open(r'f:\mypython\test.py'
,'a'
)#附加寫方式開啟,讀取報錯
>>> fd.read()
traceback (most recent call last):
file ""
, line 1,
inioerror: file not
open
forreading
>>>
2.正確讀寫方式開啟,出現亂碼
[python]
view plain
copy
>>> fd=open(r
'f:\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]
為止。所以最後得到了一些根本不期待的隨機亂字元,而不是編碼問題造成的亂碼。
解決方案:讀取之前將指標重置為檔案頭(如果讀取之後重置再讀,無效)
[python]
view plain
copy
>>> fd=open(r
'f:\mypython\test.py'
,'a+'
) >>> fd.seek(0
) >>> fd.read()
'123'
"white-space:pre"
>
#順利讀出
3.檔案裡有內容,卻讀出空字元
[python]
view plain
copy
>>> fd=open(r
'f:\mypython\test.py'
,'w+'
) #清空內容,重新寫入
>>> fd.write('456'
) >>> fd.flush()"white-space:pre"
>
#確定寫入,此時檔案內容為「456」
>>> fd.read()
''#讀出空
原因:同樣是指標問題,寫入後指標指向末尾[eof],因此讀出空
解決方案
一、呼叫close後重新開啟,指標位於開頭。(r,r+,a+,u都可以,注意不要用w,w+,a開啟)
[python]
view plain
copy
>>> 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'
"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'
二、呼叫seek指向開頭
[python]
view plain
copy
>>> fd=open(r
'f:\mypython\test.py'
,'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!')
python 檔案操作
簡明 python 教程 中的例子,python 執行出錯,用open代替file 可以執行。poem programming is fun when the work is done if you wanna make your work also fun use python f open e ...
python檔案操作
1,將乙個路徑名分解為目錄名和檔名兩部分 a,b os.path.split c 123 456 test.txt print a print b 顯示 c 123 456 test.txt 2,分解檔名的副檔名 a,b os.path.splitext c 123 456 test.txt pri...
Python 檔案操作
1.開啟檔案 如下 f open d test.txt w 說明 第乙個引數是檔名稱,包括路徑 第二個引數是開啟的模式mode r 唯讀 預設。如果檔案不存在,則丟擲錯誤 w 只寫 如果檔案 不存在,則自動建立檔案 a 附加到檔案末尾 r 讀寫 如果需要以二進位制方式開啟檔案,需要在mode後面加上...