Day6 Pyhton基础之文件操作(五)
?能調用方法的一定是對象
1.對文件操作流程
2.打開文件?
f=open('a.txt','r')的過程分析
-
- 由應用程序向操作系統發起系統調用open(...)
- 操作系統打開該文件,并返回一個文件句柄給應用程序
- 應用程序將句柄賦給變量f
打開文件的模式有:?
-
- r, 只讀模式(默認)。
- w,只寫模式。【不可讀;不存在則創建;存在則刪除內容;】
- a,追加模式。【可讀; ? 不存在則創建;存在則只追加內容;】
"+" 表示可以同時讀寫某個文件
-
- r+,可讀寫文件。【可讀;可寫;可追加】
- w+,寫讀
- a+,同a
"U"表示在讀取時,可以將 \r \n \r\n自動轉換成 \n (與 r 或 r+ 模式同使用)
-
- rU
- r+U
"b"表示處理二進制文件(如:FTP發送上傳ISO鏡像文件,linux可忽略,windows處理二進制文件時需標注)
-
- rb
- wb
- ab
- ?強調!!!
- #強調第一點: 打開一個文件包含兩部分資源:操作系統級打開的文件+應用程序的變量。在操作完畢一個文件時,必須把與該文件的這兩部分資源一個不落地回收,回收方法為: 1、f.close() #回收操作系統級打開的文件 2、del f #回收應用程序級的變量其中del f一定要發生在f.close()之后,否則就會導致操作系統打開的文件還沒有關閉,白白占用資源, 而python自動的垃圾回收機制決定了我們無需考慮del f,這就要求我們,在操作完畢文件后,一定要記住f.close()雖然我這么說,但是很多同學還是會很不要臉地忘記f.close(),對于這些不長腦子的同學,我們推薦傻瓜式操作方式:使用with關鍵字來幫我們管理上下文 with open('a.txt','w') as f:passwith open('a.txt','r') as read_f,open('b.txt','w') as write_f:data=read_f.read()write_f.write(data) 強調第一點:資源回收
?
3.文件的操作方法 1 #掌握 2 f.read() #讀取所有內容,光標移動到文件末尾 3 f.readline() #讀取一行內容,光標移動到第二行首部 4 f.readlines() #讀取每一行內容,存放于列表中 5 6 f.write('1111\n222\n') #針對文本模式的寫,需要自己寫換行符 7 f.write('1111\n222\n'.encode('utf-8')) #針對b模式的寫,需要自己寫換行符 8 f.writelines(['333\n','444\n']) #文件模式 9 f.writelines([bytes('333\n',encoding='utf-8'),'444\n'.encode('utf-8')]) #b模式 10 11 #了解 12 f.readable() #文件是否可讀 13 f.writable() #文件是否可讀 14 f.closed #文件是否關閉 15 f.encoding #如果文件打開模式為b,則沒有該屬性 16 f.flush() #立刻將文件內容從內存刷到硬盤 17 f.name View Code? 注:
1.f.readlines()是將文件中的內容存儲在列表中,列表的內容會存在內存中,當文件很大時,這將導致所占內存很大或不足
for i in f.readlines:print(i) View Code因此,可以通過for內部將f對象做成一個占內存比較小的迭代器,就像哆啦A夢的肚子一樣,里面其實裝了很多東西,
你用啥取啥到內存,用完之后會被刪除,這樣就不會占多余的內存:
for i in f:print(i) View Code2.f.tell() #查詢光標停留的位置,按字節數計算,一個漢字算3個字節
? 3.f.seek(數字) #調整光標的位置到所指定的位置
(常用,比如在傳文件的時候,突然斷了,需要斷點續傳,就要調整光標的位置,從中斷的地方傳)
4.f.flush() #可以立刻將內存中的內容刷到硬盤中(可以生成一個進度條)
1 import sys,time 2 for i in range(30): 3 sys.stdout.write('*') 4 sys.stdout.flush() #終端顯示 5 time.sleep(1) #延時 View Code? 5.f.truncate() #a模式下截斷
4.文件的修改
文件的數據是存放于硬盤上的,因而只存在覆蓋、不存在修改這么一說,我們平時看到的修改文件,都是模擬出來的效果,具體的說有兩種實現方式:
方式一:將硬盤存放的該文件的內容全部加載到內存,在內存中是可以修改的,修改完畢后,再由內存覆蓋到硬盤(word,vim,nodpad++等編輯器)
import oswith 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')?方式二:將硬盤存放的該文件的內容一行一行地讀入內存,修改完畢就寫入新文件,最后用新文件覆蓋源文件
1 import os 2 3 with open('a.txt') as read_f,open('.a.txt.swap','w') as write_f: 4 for line in read_f: 5 line=line.replace('alex','SB') 6 write_f.write(line) 7 8 os.remove('a.txt') 9 os.rename('.a.txt.swap','a.txt' View Code方式三:
1 num=0 2 with open('古詩','r',encoding='utf8') as f_read,open('古詩1','',encoding='utf8') as f_write: 3 for i in f_read: 4 num += 1 5 if num==3: 6 i=''.join([i.strip(),'oooo\n']) 7 f_write.write(i) 8 f_write.close() 9 f_read.close() View Code?
轉載于:https://www.cnblogs.com/weinapang/p/9111012.html
總結
以上是生活随笔為你收集整理的Day6 Pyhton基础之文件操作(五)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据库出现的bug原因以及解决方法
- 下一篇: 射频与微波测量之S参数