萬惡之源 檔案操作

2022-08-21 19:33:09 字數 2586 閱讀 7866

檔案操作:  f = open(檔名, mode="模式", encoding="編碼格式")

模式: r, w, a, r+, w+, a+, rb, wb, ab, r+b, w+b, a+b
#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)

view code

#

1. 開啟檔案的模式有(預設為文字模式):

r ,唯讀模式【預設模式,檔案必須存在,不存在則丟擲異常】

w,只寫模式【不可讀;不存在則建立;存在則清空內容】

a, 只追加寫模式【不可讀;不存在則建立;存在則只追加內容】

#rb

wbab

注:以b方式開啟時,讀取到的內容是位元組型別,寫入時也需要提供位元組型別,不能指定編碼

#3,『+』模式(就是增加了乙個功能)

r+, 讀寫【可讀,可寫】

w+,寫讀【可寫,可讀】

a+, 寫讀【可寫,可讀】

#4,以bytes型別操作的讀寫,寫讀,寫讀模式

r+b, 讀寫【可讀,可寫】

w+b,寫讀【可寫,可讀】

a+b, 寫讀【可寫,可讀】

seek() 移動游標到xx位置    開頭: seek(0), 末尾: seek(0,2)
檔案修改

建立新檔案. 把修改後的內容寫入新檔案. 刪除老檔案. 重新命名新檔案

import os

os.remove("")刪除檔案

os.rename("原始檔", "新檔名") 重新命名檔案

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

') #

將新建的檔案重新命名為原檔案

f.read() #

讀取所有內容,游標移動到檔案末尾

f.readline() #

讀取一行內容,游標移動到第二行首部

f.readlines() #

讀取每一行內容,存放於列表中

f.write('1111\n222\n') #針對文字模式的寫,需要自己寫換行符

f.write('1111\n222\n'.encode('utf-8')) #針對b模式的寫,需要自己寫換行符

f.writelines(['333\n','444\n']) #檔案模式

f.writelines([bytes('333\n',encoding='utf-8'),'444\n'.encode('utf-8')]) #b模式

#了解f.readable() #檔案是否可讀

f.writable() #檔案是否可讀

f.closed #檔案是否關閉

f.encoding #如果檔案開啟模式為b,則沒有該屬性

f.flush() #立刻將檔案內容從記憶體刷到硬碟

萬惡之源 再談編碼

1.is和 區別 id 內建函式 判斷兩邊的值 is 判斷記憶體位址 回顧編碼 1.ascii 英文,特殊字元,數字,8bit,1byte 2.gbk 中文 16bit,2byte.相容ascii 3.unicode 萬國碼,32bit 4byte.相容ascii 4.utf 8 長度可變的unic...

過早優化是萬惡之源

don t cut yourself code optimization as a double edged sword。中文翻譯 過早優化是萬惡之源。優化的好處多多,但是這並不意味著所有的 都需要進行優化,有時過度的優化反而適得其反 費時 費力 不討好。現代電腦科學的鼻祖 donald knuth...

05 萬惡之源 基本資料型別 dict

1.字典的簡單介紹 2.字典增刪改查和其他操作 3.字典的巢狀 一.字典的介紹 字典 dict 是python中唯一的乙個對映型別.他是以括起來的鍵值對組成.在dict中key是唯一的.在儲存的時候,根據key來計算出乙個記憶體的位址.然後將key value儲存在這個位址中.這種演算法被稱為has...