Python檔案的高階應用

2021-09-26 05:59:45 字數 1705 閱讀 1132

'''

'''# wt

with open('36w.txt', 'wt', encoding='utf-8') as fw:

print(fw.readable())

print(fw.writable())

false

true

# w+t

with open('36w.txt', 'w+t', encoding='utf-8') as fw:

print(fw.readable())

print(fw.writable())

true

true

# r+t

with open('36w.txt', 'r+t', encoding='utf-8') as fr:

print(fr.readable())

print(fr.writable())

true

true

假設我們需要在檔案內容中間的某一行增加內容,如果使用基礎的r/w/a模式實現是非常困難的,因此我們需要對檔案內的指標進行移動。

with open('36r.txt', 'r+t', encoding='utf-8') as fr:

fr.readline()

fr.write('nick 真衰呀') # 寫在檔案的最後一行

硬碟上從來沒有修改一說,硬碟上只有覆蓋,即新內容覆蓋新內容。

1.seek(offset,whence): offset代表檔案指標的偏移量,偏移量的單位是位元組個數

# seek()

with open('36r.txt', 'rb') as fr:

print(f"fr.seek(4, 0): ") # 0相當於檔案頭開始;1相當於當前檔案所在位置;2相當於檔案末尾

# fr.seek(0,2) # 切換到檔案末尾

fr.seek(4, 0): 3

2.tell(): 每次統計都是從檔案開頭到當前指標所在位置

'''

'''# tell()

with open('36r.txt', 'rb') as fr:

fr.seek(4, 0)

print(f"fr.tell(): ")

fr.tell(): 4

3.read(n): 只有在模式下的read(n),n代表的是字元個數,除此之外,其他但凡涉及檔案指標的都是位元組個數

# read()

with open('36r.txt', 'rt', encoding='utf-8') as fr:

print(f"fr.read(3): ")

fr.read(3): sdf

4.truncate(n): truncate(n)是截斷檔案,所以檔案的開啟方式必須可寫,但是不能用w或w+等方式開啟,因為那樣直接清空檔案了,所以truncate()要在r+或a或a+等模式下測試效果。它的參照物永遠是檔案頭。並且truncate()不加引數,相當於清空檔案。

# truncate()

with open('36r.txt', 'ab') as fr:

fr.truncate(2) # 截斷2個位元組後的所有字元,如果3個位元組乙個字元,只能截斷2/3個字元,還會遺留1/3個字元,會造成亂碼

檔案的高階應用

copy wt with open 36w.txt wt encoding utf 8 as fw print fw.readable print fw.writable copyfalse true copy w t with open 36w.txt w t encoding utf 8 as ...

python函式的高階應用詳解

函式是我們所熟知的,在python中函式的定義格式如下 def 函式名 形式引數 函式體 函式的封裝就是實現 塊的復用,python內建了一些基礎的函式,開發者也可以自己定義函式,函式只能先定義,再進行呼叫。1 程式遇到函式呼叫的情況時,暫停執行 2 將實際引數值傳遞給函式引數 3 執行函式體語句 ...

從檔案處理到檔案的高階應用

操作檔案的流程 1.開啟檔案 乁.檔案路徑 尓.開啟模式,w write 厁f open r c users jinyy desktop 新建資料夾 nick罰站.png w encoding utf8 2.修改 讀取檔案 3.儲存檔案 f.flush 4.關閉檔案 python 真的能操作檔案碼,...