python 檔案讀取 一

2021-08-15 03:59:03 字數 3679 閱讀 8214

在專案開始階段 寫入基礎資料是很正常的,經常和讀寫檔案打交道這樣就需要 對相關知識比較熟悉

一般是通過open檔案來實現 上下文管理器來實現,開啟和關閉檔案

with open(「a.txt」, 「r」, encoding=」utf-8」) as f:

pass

檔案使用方式標識

『r』:預設值,表示從檔案讀取資料。

』 w』:表示要向檔案寫入資料,並截斷以前的內容

『a』:表示要向檔案寫入資料,新增到當前內容尾部

『r+』:表示對檔案進行可讀寫操作(刪除以前的所有資料)

『r+a』:表示對檔案可進行讀寫操作(新增到當前檔案尾部)

『b』:表示要讀寫二進位制資料

r唯讀,r+讀寫,不建立

w新建只寫,w+新建讀寫,二者都會將檔案內容清零

(以w方式開啟,不能讀出。w+可讀寫)

**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+

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

若不存在會建立新檔案的開啟方式:a,a+,w,w+

>>> fd=open(r'f:\mypython\test.py','w')    #唯讀方式開啟,讀取報錯  

>>> fd.read()

traceback (most recent call last):

file "", line 1, in

ioerror: file not open for reading

>>> fd=open(r'f:\mypython\test.py','a')#附加寫方式開啟,讀取報錯

>>> fd.read()

traceback (most recent call last):

file "", line 1, in

ioerror: file not open for reading

>>>

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

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]為止。所以最後得到了一些根本不期待的隨機亂字元,而不是編碼問題造成的亂碼。

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

>>> fd=open(r'f:\mypython\test.py','a+')  

>>> fd.seek(0)

>>> fd.read()

'123'

"white-space:pre">

#順利讀出

3.檔案裡有內容,卻讀出空字元

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開啟)

>>> 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指向開頭

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取負值。
記得close()關閉

當我們寫檔案時,作業系統往往不會立刻把資料寫入磁碟,而是放到記憶體快取起來,空閒的時候再慢慢寫入。只有呼叫close()方法時,作業系統才保證把沒有寫入的資料全部寫入磁碟。忘記呼叫close()的後果是資料可能只寫了一部分到磁碟,剩下的丟失了。所以,還是用with語句來得保險:

with open(『/users/michael/test.txt』, 『w』) as f:

f.write(『hello, world!』)

python高階讀取檔案 Python讀取檔案內容

開啟檔案之後,就可以讀取檔案的內容,檔案物件提供多種讀取檔案內容的方法。開啟test.txt檔案 f open test.txt r 開啟test.txt檔案 f.close 關閉檔案 test.txt檔案有以下內容 hello world.hello python.hello imooc.讀取若干...

Python檔案讀取

python提供了多種方法實現檔案讀取操作 1 read 2 readline 3 readlines 4 xreadlines 很多人也在糾結到底應該選擇哪種方式,甚至疑問在處理大檔案時應該選擇哪種方式,因為擔心檔案過大導致記憶體佔用率過高甚至無法完全載入。其實,這個問題是多餘的,在引入了迭代器和...

python檔案讀取

1.讀取txt檔案 read 讀取整行檔案 readline 讀取一行資料 readines 讀取所有行的資料 讀取txt檔案 user file open user info.txt r lines user file.readlines forline inlines username line...