python基礎-開啟模式、seek、修改檔案、with上下文管理、truncate
檔案的開啟模式
開啟檔案的模式有(預設為文字模式):
r ,只讀模式【預設模式,檔案必須存在,不存在則丟擲異常】
w,只寫模式【不可讀;不存在則建立;存在則清空內容】
a, 之追加寫模式【不可讀;不存在則建立;存在則只追加內容】對於非文字檔案,我們只能使用b模式,”b”表示以位元組的方式操作(而所有檔案也都是以位元組的形式儲存的,使用這種模式無需考慮文字檔案的字元編碼、圖片檔案的jgp格式、視訊檔案的avi格式)
rb
wb
ab
注:以b方式開啟時,讀取到的內容是位元組型別,寫入時也需要提供位元組型別,不能指定編碼
以上的模式,在上篇部落格中已經總結了,接下來看看如下的模式
“+” 表示可以同時讀寫某個檔案
r+, 讀寫【可讀,可寫】
w+,寫讀【可讀,可寫】
a+, 寫讀【可讀,可寫】
x, 只寫模式【不可讀;不存在則建立,存在則報錯】
x+ ,寫讀【可讀,可寫】
r+用法
r+
可讀可寫
先讀後寫:寫是追寫
先寫後讀:從頭開始寫
file檔案寫入之前的文字是
嗯i啊en呢
我們看如下程式碼進行寫入,看看file文字如何變化
f = open("read","r+",encoding="utf-8")
print(f.writable(),f.readable())
f.write("蒽")
print(f.read())
f.close()
輸出如下:
True True
i啊en呢
我們看下file檔案內的文字:
蒽i啊en呢
我們繼續上面file檔案內容-蒽i啊en呢 來做測試,測試程式碼如下
f = open ("read","r+",encoding="utf-8")
print(f.writable(),f.readable())
f.write("o")
f.close()
我們看下最終的file目錄下的內容
o��i啊en呢
我們看是有亂碼的,為啥呢?
因為之前檔案內容是—蒽i啊en呢 在開始追寫一個’o’ 是一個位元組,由於file檔案中第一個字是蒽 ,所以會造成位元組亂碼
w+用法
w+ 可讀可寫,一上來檔案清空了,游標在最後,需要移動游標才可讀
我們將file檔案內容修改如下:
ac啊
sss
然後看測試程式碼如下:
f = open("read" ,"w+",encoding="utf-8")
f.write("嗯i")
f.write("啊")
f.seek(0)
print(f.read())
f.close()
結果輸出如下:
嗯i啊
寫入file後的內容是:
嗯i啊
a+用法
a+ 寫讀【可讀,可寫】
file檔案內容如下:
嗯i啊
我們看測試程式碼如下:
f = open("tsst","a+",encoding="utf-8")
print(f.tell())
f.write("en呢")
f.seek(0)
print(f.read())
f.close()
結果輸出如下:
7
嗯i啊en呢
file檔案內容如下:
嗯i啊en呢
修改檔案
print("-----檔案修改----")
#建立新檔案
f2 = open("原檔案.bak","w",encoding="utf-8")
#讀取原檔案內容
f = open("原檔案","a+",encoding="utf-8")
for i in range(5):
f.write("原檔案內容\n")
f.seek(0)
#操作讀取內容,把字串內容替換掉
#將替換後的寫入到新檔案中
for i in f:
old = i.strip()
print(old)
new = old.replace("原","新")
print(new)
f2.write(new+"\n")
f.close()
f2.close()
#刪除原檔案,重新命名新檔案
import os
os.remove("原檔案")
os.renames("原檔案.bak","原檔案_")
with用法
開啟一個檔案包含兩部分資源:作業系統級開啟的檔案+應用程式的變數。在操作完畢一個檔案時,必須把與該檔案的這兩部分資源一個不落地回收,回收方法為:
1、f.close() #回收作業系統級開啟的檔案
2、del f #回收應用程式級的變數
其中del f一定要發生在f.close()之後,否則就會導致作業系統開啟的檔案還沒有關閉,白白佔用資源,
而python自動的垃圾回收機制決定了我們無需考慮del f,這就要求我們,在操作完畢檔案後,一定要記住f.close()
雖然我這麼說,但是很多同學還是會很不要臉地忘記f.close(),對於這些不長腦子的同學,我們推薦傻瓜式操作方式:使用with關鍵字來幫我們管理上下文
seek用法
檔案內容是
嗯i
f = open("tsst",'r+',encoding="utf-8")
f.seek(0)
print(f.tell())
str = f.read(1)
print(str)
print("-------")
f.seek(3)
print(f.tell())
str = f.read(1)
print(str)
print("-------")
#移動到末尾
f.seek(0,2)
print(f.tell())
print("-------")
f.seek(7)
print(f.tell())
f.close()
輸出如下:
E:\python\python_sdk\python.exe E:/python/py_pro/test.py
0
嗯
-------
3
i
-------
4
-------
7
Process finished with exit code 0
truncate用法
truncate是截斷檔案,所以檔案的開啟方式必須可寫,但是不能用w或w+等方式開啟,因為那樣直接清空檔案了,所以truncate要在r+或a或a+等模式下測試效果
“””
truncate(n): 從檔案的首行首字元開始截斷,截斷檔案為n個字元;
無n表示從當前位置起截斷;截斷之後n後面的所有字元被刪除。
其中win下的換行代表2個字元大小。
truncate是截斷檔案,所以檔案的開啟方式必須可寫,但是不能用w或w+等方式開啟,因為那樣直接清空檔案了,
所以truncate要在r+或a或a+等模式下測試效果
“”“
原檔案內容是:
新檔案內容
f = open("tsst","a",encoding="utf-8")
#file檔案內容新
str = f.truncate(3)
print(str)
f.close()
輸出如下:
3
程式碼執行後,檔案內容變為
新
我們繼續看另外一種方法,將file檔案內容迴歸如下:
新檔案內容
看程式碼如下:
f = open("tsst","a",encoding="utf-8")
f.seek(3)
f.truncate()
print(str)
f.close()
檔案內容變為
新