電腦系統分為:硬體,操作系統,應用程式 硬體:目的在於運行軟體發出的指令。硬體包括CPU,記憶體,硬碟 多數CPU都有兩種模式,即內核態與用戶態。 ①當cpu處於內核狀態時,運行的是操作系統,能控制硬體(可以獲取所有cpu的指令集) ②當cpu處於用戶太狀態時,運行的是用戶軟體,不能控制硬體(可以獲 ...
電腦系統分為:硬體,操作系統,應用程式 硬體:目的在於運行軟體發出的指令。硬體包括CPU,記憶體,硬碟 多數CPU都有兩種模式,即內核態與用戶態。 ①當cpu處於內核狀態時,運行的是操作系統,能控制硬體(可以獲取所有cpu的指令集) ②當cpu處於用戶太狀態時,運行的是用戶軟體,不能控制硬體(可以獲取所有cpu的指令集中的一個子集,該子集不包括操作硬體的指令集)
4.1操作文件流程:
#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()
雖然我這麼說,但是很多同學還是會很不要臉地忘記f.close(),對於這些不長腦子的同學,我們推薦傻瓜式操作方式:使用with關鍵字來幫我們管理上下文
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)
4.2文件編碼
f=open(...)是由操作系統打開文件,那麼如果我們沒有為open指定編碼,那麼打開文件的預設編碼很明顯是操作系統說了算了,
操作系統會用自己的預設編碼去打開文件,在windows下是gbk,在linux下是utf-8。
若要保證不亂碼,文件以什麼方式存的,就要以什麼方式打開。
f=open('a.txt','r',encoding='utf-8')
4.3文件的打開模式
#1. 打開文件的模式有(預設為文本模式):
r ,只讀模式【預設模式,文件必須存在,不存在則拋出異常】
w,只寫模式【不可讀;不存在則創建;存在則清空內容】
a, 只追加寫模式【不可讀;不存在則創建;存在則只追加內容】
#2. 對於非文本文件,我們只能使用b模式,"b"表示以位元組的方式操作
(而所有文件也都是以位元組的形式存儲的,使用這種模式無需考慮文本文件的字元編碼、圖片文件的jgp格式、視頻文件的avi格式)
rb
wb
ab
註:以b方式打開時,讀取到的內容是位元組類型,寫入時也需要提供位元組類型,不能指定編碼
#3,‘+’模式(就是增加了一個功能)
r+, 讀寫【可讀,可寫】
w+,寫讀【可寫,可讀】
a+, 寫讀【可寫,可讀】
#4,以bytes類型操作的讀寫,寫讀,寫讀模式
r+b, 讀寫【可讀,可寫】
w+b,寫讀【可寫,可讀】
a+b, 寫讀【可寫,可讀】
4.4文件操作方法
4.4.1常用操作方法
read(3):
1. 文件打開方式為文本模式時,代表讀取3個字元 2. 文件打開方式為b模式時,代表讀取3個位元組 其餘的文件內游標移動都是以位元組為單位的如:seek,tell,truncate 註意: 1. seek有三種移動方式0,1,2,其中1和2必須在b模式下進行,但無論哪種模式,都是以bytes為單位移動的 2. truncate是截斷文件,所以文件的打開方式必須可寫,但是不能用w或w+等方式打開,因為那樣直接清空文件了,所以truncate要在r+或a或a+等模式下測試效果。4.5文件的修改
文件的數據是存放於硬碟上的,因而只存在覆蓋、不存在修改這麼一說,我們平時看到的修改文件,都是模擬出來的效果,具體的說有兩種實現方式: 方式一:將硬碟存放的該文件的內容全部載入到記憶體,在記憶體中是可以修改的,修改完畢後,再由記憶體覆蓋到硬碟(word,vim,nodpad++等編輯器)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') #將新建的文件重命名為原文件
方式二:將硬碟存放的該文件的內容一行一行地讀入記憶體,修改完畢就寫入新文件,最後用新文件覆蓋源文件
import os
with 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')