目錄
- 一.文件基本操作
- 1.1 文件打開和關(guān)閉
- 1.2 讀/寫文件
- 二. 文件備份腳本
- 總結(jié)
一.文件基本操作
1.1 文件打開和關(guān)閉
- open(‘文件名稱','打開模式')
- 模式:r(只讀,指針再頭) w(只寫,存在覆蓋,不存創(chuàng)新) a(追加) b(二進(jìn)制格式)
- close() 方法關(guān)閉文件
f=open('text.txt','w')#創(chuàng)建text.txt文件,用f來指代
f.close()#關(guān)閉文件
注意: 打開一個(gè)文件之后,一定要關(guān)閉,否則后面無法繼續(xù)操作這個(gè)文件
with
上下文管理,不管在處理文件過程中是否發(fā)生異常,都能保證 with 語句執(zhí)行完畢后已經(jīng)關(guān)閉打開的文件句柄。
def main():
with open('text.txt','w+') as f:
content=f.read()#讀取文件寫入內(nèi)容
print(content)#輸出
main()#輸出完成后會(huì)自動(dòng)關(guān)閉文件
錯(cuò)誤:如果報(bào)錯(cuò)io.UnsupportedOperation: not readable
因?yàn)槟闶怯?code>open打開一個(gè)文件,此時(shí)調(diào)用的是w
寫入模式,下面使用read
是沒有權(quán)限的,你得使用w+
讀寫模式
1.2 讀/寫文件
1.2.1 寫文件
寫文件 write
默認(rèn)的編碼是gbk
這個(gè)是中文編碼,最好的習(xí)慣呢就是我們?cè)?strong>打開一個(gè)文件的時(shí)候給它指定一個(gè)編碼類型encoding
,要不然會(huì)出現(xiàn)亂碼
f=open('text.txt','w',encoding='utf-8')#w為寫入模式
f.write('人生苦短,我用python')#寫入文件text.txt
f.close()
#writelines()可傳一個(gè)可迭代對(duì)象
f=open('text.txt','a',encoding='utf-8')#a為追加模式
他會(huì)自動(dòng)生成text文件然后寫入
writelines 方法將可迭代對(duì)象,迭代寫入文件
f.write('\r\n')
f.writelines(['人生','就是','不斷的學(xué)習(xí)'])
print('\n')
f.close()
1.2.2 讀文件
read(num):傳入一個(gè)數(shù)字做參數(shù),表示讀取指定字符個(gè)數(shù)。列:read(1)
readlines() :按行讀取,一次性讀取所有內(nèi)容,返回一個(gè)列表,每一行內(nèi)容作為一個(gè)元素。
readline() :按行讀取,但是一次只讀取一行。
#讀取文件
f=open('text.txt','r',encoding='utf-8')#只讀模式
print(f.read())#全部讀取輸出
f.close()
注意:出現(xiàn)UnicodeDecodeError: ‘gbk' codec can't decode byte 0xad in position 52: illegal multibyte sequence錯(cuò)誤
解決:open中加入encoding=‘utf-8'就行
二. 文件備份腳本
利用腳本完成自動(dòng)備份,要求用戶輸入文件名稱,完成自動(dòng)備份
def copyfile():
#接收輸入的文件
old_file=input('請(qǐng)輸入要備份的文件:')
file_list=old_file.split(".")#split()函數(shù)通過指定分隔符對(duì)字符串進(jìn)行切片,假設(shè)要備份text.txt文件,輸出是['text', 'txt']
new_file=file_list[0]+'_備份.'+file_list[1]#構(gòu)造新的文件名,加上備份后綴
old_f=open(old_file,'r')#只讀模式打開備份的文件
new_f=open(new_file,'w')#只寫模式打開新文件,不存在則創(chuàng)建
new_f.write(old_f.read())#將備份文件內(nèi)容讀取出來寫入新文件
#關(guān)閉所有打開文件
old_f.close()
new_f.close()
copyfile()#到時(shí)候文件夾里面會(huì)出現(xiàn)一個(gè)text_備份.txt的文件,內(nèi)容和備份文件一樣
如果處理超大文件,一次將全部內(nèi)容讀取出來顯然是不合適的,在上面代碼的基礎(chǔ)上改進(jìn)下代碼,讓它備份大文件也不會(huì)導(dǎo)致內(nèi)存被占滿。
def copyfile2():
#接收輸入的文件
old_file=input('輸入要備份的文件')
#如果沒有輸入或者輸入錯(cuò)誤就提示
if not old_file:
print('輸入錯(cuò)誤')
old_file = input('輸入要備份的文件:')
else:
file_list=old_file.split(".")
print(file_list)
#創(chuàng)造新的文件名,加上備份后綴
if len(file_list)2:#如果列表長度小于2,就不用加.
new_file=file_list[0]+'_備份2'
pass
else:#文件有后綴的情況
new_file=file_list[0]+'_備份2.'+file_list[1]
#用異常處理判斷內(nèi)存是否被占滿
try:
#同時(shí)打開需要備份的文件,新文件
with open(old_file,'r') as old_f, open(new_file,'a') as new_f:
while True:
content=old_f.read(2048)#一次讀取2048個(gè)字符
new_f.write(content)#寫入
#當(dāng)讀取的內(nèi)容字符長度小于2048是說明讀取完畢
if len(content)2048:
break#跳出循環(huán)
except Exception as e:
print(e)#如果內(nèi)存滿無法讀取了,就拋出異常
copyfile2()#到時(shí)候文件夾里面會(huì)出現(xiàn)一個(gè)text_備份2.txt的文件,內(nèi)容和備份文件一樣
備份了text.txt
總結(jié)
到此這篇關(guān)于python必學(xué)知識(shí)之文件操作的文章就介紹到這了,更多相關(guān)python文件操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- python文件和目錄操作方法大全(含實(shí)例)
- Python 文件讀寫操作實(shí)例詳解
- 在Python程序中進(jìn)行文件讀取和寫入操作的教程
- python中os操作文件及文件路徑實(shí)例匯總
- Python中的文件和目錄操作實(shí)現(xiàn)代碼
- python操作xml文件詳細(xì)介紹
- python讀取csv文件示例(python操作csv)
- 在Python中操作文件之seek()方法的使用教程
- Python中操作文件之write()方法的使用教程
- python之文件的讀寫和文件目錄以及文件夾的操作實(shí)現(xiàn)代碼