1、文件處理流程
1.打開文件,獲得文件句柄並賦值給一個變量ide
2.經過句柄對文件進行操做工具
3.關閉文件post
r模式,默認模式,文件不存在則報錯測試
w模式,文件不存在則建立,文件存在則覆蓋ui
a模式,文件不存在則建立,文件存在則不會覆蓋,寫內容會以追加的方式寫(寫日誌文件的時候經常使用),追加模式是一種特殊的寫模式編碼
b(rb,wb,ab)模式:不用加encoding:utf-8spa
1 f=open('c.txt','rb') 2 # print(f.read()) 3 print(f.read().decode()) 4 5 f=open('d.txt','wb') 6 f.write('啦啦啦'.encode('utf-8')) 7 f.close()
2、基本操做
1.文件打開模式日誌
文件句柄=open('文件路徑',‘模式’)code
打開文件時,須要指定文件路徑和以什麼方式打開文件。視頻
打開文件的模式有:
- r ,只讀模式【默認模式,文件必須存在,不存在則拋出異常】
- w,只寫模式【不可讀;不存在則建立;存在則清空內容】
- x, 只寫模式【不可讀;不存在則建立,存在則報錯】
- a, 追加模式【可讀; 不存在則建立;存在則只追加內容】
-
# #只讀模式 # f=open(r'c.txt',encoding='utf-8') # # print('====>1',f.read()) # # print('====>2',f.read()) # # print(f.readable()) # # print(f.readline(),end='') # # print(f.readline()) # # print("="*20) # # print(f.read()) # print(f.readlines()) # f.close() #寫模式:文件不存在則建立,文件存在則覆蓋原有的 # f=open("new.py",'w',encoding='utf-8') # f.write('1111111111\n') # f.writelines(['2222\n','2222548\n','978646\n']) # f.close() # 追加模式:文件不存在則建立,文件存在不會覆蓋,寫內容是追加的方式寫 # f=open('new.py','a',encoding='utf-8') # f.write('nishishui\n') # f.writelines(['aa\n','bb\n']) # f.close()
"+" 表示能夠同時讀寫某個文件
- r+, 讀寫【可讀,可寫】
- w+,寫讀【可讀,可寫】
- x+ ,寫讀【可讀,可寫】
- a+, 寫讀【可讀,可寫】
"b"表示以字節的方式操做
- rb 或 r+b
- wb 或 w+b
- xb 或 w+b
- ab 或 a+b
注:以b方式打開時,讀取到的內容是字節類型,寫入時也須要提供字節類型,不能指定編碼
練習,利用b模式,編寫一個cp工具,要求以下:
1. 既能夠拷貝文本又能夠拷貝視頻,圖片等文件
1 # b模式 2 f=open('1.jpg','rb') 3 data=f.read() 4 # print(data) 5 f=open('2.jpg','wb') 6 f.write(data) 7 print(data)
3、上下文管理
1. with open('a.txt','w') as f:
pass
2.with open('a.txt','r') as read_f,open('b.txt','w') as write_f:
data=read_f.read()
write_f.write(data)
4、文件的修改
1 import os 2 with open('a.txt','r',encoding='utf-8') as read_f,\ 3 open('a.txt.swap','w',encoding='utf-8') as write_f: 4 for line in read_f: 5 write_f.write(line) 6 7 os.remove('a.txt') 8 os.rename('.a.txt.swap','a.txt')
5、文件內光標移動
一: read(3):
1. 文件打開方式爲文本模式時,表明讀取3個字符
2. 文件打開方式爲b模式時,表明讀取3個字節
二: 其他的文件內光標移動都是以字節爲單位如seek,tell,truncate
注意:
1. seek有三種移動方式0,1,2,其中1和2必須在b模式下進行,但不管哪一種模式,都是以bytes爲單位移動的
seek控制光標的移動,是以文件開頭做爲參照的。
tell當前光標的位置
2. truncate是截斷文件,截斷必須是寫模式,可是不能用w或w+等方式打開,由於那樣直接清空文件了,因此truncate要在r+或a或a+等模式下測試效果
1 import time 2 with open('test.txt','rb') as f: 3 f.seek(0,2) 4 while True: 5 line=f.readline() 6 if line: 7 print(line.decode('utf-8')) 8 else: 9 time.sleep(0.2)