可讀、可寫
- r+t: 可讀、可寫
- w+t: 可寫、可讀
- a+t: 可追加、可讀
## 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): {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()}")
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)}")
#學習中遇到問題沒人解答?小編創建了一個Python學習交流群:711312441
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個字符,會造成亂碼
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/545828.html
標籤:其他
上一篇:nacos簡單使用
