計算機系統分為:計算機硬體,作業系統,應用程式三部分。
我們用python或其他語言編寫的應用程式若想要把資料永久儲存下來,必須要儲存於硬碟中,這就涉及到應用程式要操作硬體,眾所周知,應用程式是無法直接操作硬體的,這就用到了作業系統。作業系統把複雜的硬體操作封裝成簡單的介面給使用者/應用程式使用,其中檔案就是作業系統提供給應用程式來操作硬碟虛擬概念,使用者或應用程式通過操作檔案,可以將自己的資料永久儲存下來。
檔案的操作流程:
#1. 開啟檔案,得到檔案控制代碼並賦值給乙個變數f=open('a.txt','r',encoding='utf-8') #預設開啟模式就為r,路徑有絕對路徑和相對路徑
#2. 通過控制代碼對檔案進行操作
data=f.read()
#3. 關閉檔案
f.close()
關閉檔案的注意事項:
開啟乙個檔案包含兩部分資源:作業系統級開啟的檔案+應用程式的變數。在操作完畢乙個檔案時,必須把與該檔案的這兩部分資源乙個不落地**,**方法為:1、f.close() #
**作業系統級開啟的檔案
2、del f #
**應用程式級的變數
其中del f一定要發生在f.close()之後,否則就會導致作業系統開啟的檔案還沒有關閉,白白占用資源,
而python自動的垃圾**機制決定了我們無需考慮del f,這就要求我們,在操作完畢檔案後,一定要記住f.close()
with open(
'a.txt
','w
') as f:
pass
with open(
'a.txt
','r
') as read_f,open('
b.txt
','w
') as write_f:
data=read_f.read()
write_f.write(data)
f=open(...)是由作業系統開啟檔案,那麼如果我們沒有為open指定編碼,那麼開啟檔案的預設編碼很明顯是作業系統說了算了,作業系統會用自己的預設編碼去開啟檔案,在windows下是gbk,在linux下是utf-8。
#這就用到字元編碼的知識:若要保證不亂碼,檔案以什麼方式存的,就要以什麼方式開啟。f=open('a.txt','r',encoding='utf-8')
檔案控制代碼 = open(『檔案路徑』,『模式』)
#1. 開啟檔案的模式有(預設為文字模式):r ,唯讀模式【預設模式,檔案必須存在,不存在則丟擲異常】
w,只寫模式【不可讀;不存在則建立;存在則清空內容】
a, 只追加寫模式【不可讀;不存在則建立;存在則只追加內容】
rb wb
ab注:以b方式開啟時,讀取到的內容是位元組型別,寫入時也需要提供位元組型別,不能指定編碼
#3,『+』模式(就是增加了乙個功能)
r+, 讀寫【可讀,可寫】
w+,寫讀【可寫,可讀】
a+, 寫讀【可寫,可讀】
#4,以bytes型別操作的讀寫,寫讀,寫讀模式
r+b, 讀寫【可讀,可寫】
w+b,寫讀【可寫,可讀】
a+b, 寫讀【可寫,可讀】
常用操作方法。
read(3):
1. 檔案開啟方式為文字模式時,代表讀取3個字元
2. 檔案開啟方式為b模式時,代表讀取3個位元組
其餘的檔案內游標移動都是以位元組為單位的如:seek,tell,truncate
#seek _ 指定游標移動到某個位置
#tell _ 獲取游標當前的位置
#truncate _ 擷取檔案
注意:1. seek有三種移動方式0,1,2,其中1和2必須在b模式下進行,但無論哪種模式,都是以bytes為單位移動的
2. truncate是截斷檔案,所以檔案的開啟方式必須可寫,但是不能用w或w+等方式開啟,因為那樣直接清空檔案了,所以truncate要在r+或a或a+等模式下測試效果。
f = open('log',mode='r+',encoding='utf-8')content = f.read(3) # 讀出來的都是字元
f.seek(3) # 是按照位元組定游標的位置
f.tell() #告訴你游標的位置
print(f.tell())
content = f.read()
print(content)
f.tell()
f.readable() # 是否刻度
line = f.readline() # 一行一行的讀
line = f.readlines() # 每一行當成列表中的乙個元素,新增到list中
f.truncate(4)
for line in f:
print(line)
f.close()
檔案的資料是存放於硬碟上的,因而只存在覆蓋、不存在修改這麼一說,我們平時看到的修改檔案,都是模擬出來的效果,具體的說有兩種實現方式:
import os #呼叫系統模組
with open(
'a.txt
') as read_f,open('
.a.txt.swap
','w
') as write_f:
data=read_f.read() #
全部讀入記憶體,如果檔案很大,會很卡
data=data.replace('
alex
','sb
') #
在記憶體中完成修改
write_f.write(data)
#一次性寫入新檔案
os.remove(
'a.txt
') #
刪除原檔案
os.rename('
.a.txt.swap
','a.txt
') #
將新建的檔案重新命名為原檔案
方式二:將硬碟存放的該檔案的內容一行一行地讀入記憶體,修改完畢就寫入新檔案,最後用新檔案覆蓋原始檔
importoswith open(
'a.txt
') as read_f,open('
.a.txt.swap
','w
') as write_f:
for line in
read_f:
line=line.replace('
alex
','sb')
write_f.write(line)
os.remove(
'a.txt')
os.rename(
'.a.txt.swap
','a.txt
')
總結:
# 檔案處理# 開啟檔案
#open('路徑','開啟方式','指定編碼方式')
# 開啟方式 r w a r+ w+ a+ b
#r+ 開啟檔案直接寫 和讀完再寫
# 編碼方式 —— utf-8
# 操作檔案
# 讀# read 一次性讀
# readlines 一次性讀
# readline 一行一行讀
#不知道在哪兒結束
# for迴圈 —— 最好!!!
# 寫# write
# 游標 —— 檔案指標
#seek _ 指定游標移動到某個位置
#tell _ 獲取游標當前的位置
#truncate _ 擷取檔案
# 關閉檔案
#close
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後面加上...