open
Python提供瞭非常方便的档案讀寫功能,其中open
是讀寫档案的第一步,通過open
讀寫档案的方式和把大象裝冰箱是一樣的
f = open("test.txt",'w') #第一步,把冰箱門(档案)打開 f.write("this is content") #第二步,把大象(档案內容)裝進去 f.close() #第三步,把冰箱門關上,否則大象可能會跑掉
open
的定義方式為
file=open(path,mode='r',buffering=-1,encoding=None)
其中,
path
為档案路徑mode
為讀取模式,默認為r
,即隻讀模式。buffering
為緩沖區,由於內存的讀寫速度快於外設,所以大部分情況不用設,即不大於0。encoding
為編碼方式- 最後,輸出的
file
是一個档案對象。
其中,mode
包括以下幾種
r | r+ | w | w+ | a | a+ | |
---|---|---|---|---|---|---|
b | rb | rb+ | wb | wb+ | ab | ab+ |
其中,b表示二進制,r表示讀,w表示寫,a表示追加。無論什麼模式,有+
則意味著可讀可寫。寫入一般會覆蓋原档案,追加則在原档案尾部開始寫。如果档案不存在,w, w+, a, a+, wb
會創建新档案。
档案對象
通過open
創建的档案對象,除瞭用於關閉档案的close
之外,有兩組最常用的函數,即代表讀寫的read
和write
,分別用於讀寫,其區別如下
read | write | 讀寫整個档案 read(size)可讀取size大小的档案 |
readline | 每次讀一行 由於write直接輸入字符串,故不必設置writeline |
|
readlines | writelines | 前者按行讀取档案,並存入一個字符串列表 writelines將一個字符串列表的形式寫入档案 |
例如
>>> f = open('test.txt','w') >>> f.writelines(['a','b','c\n','d']) >>> f.close() >>> f = open('test.txt','r') >>> f.readlines() ['abc\n', 'd'] #在寫lines的時候,並不會自動添加\n >>> f.close()
根據我電腦的性能,讀取500M的txt就要超過1s,讀取2G的档案多半要報錯。這個時候需要通過seek
函數來指定偏移量,然後在偏移處的位置對档案進行讀寫操作。其輸入為f.seek(offset,whence=0)
其中
offset
為偏移量whence
為偏移方式,為0時表示絕對定位;為1時表示相對定位;為2表示從末尾定位。
從seek
的視角來看,open
档案時,如果用瞭w
,則代表seek(0)
,如果用瞭a
,則代表seek(0,2)
。
通過tell
可以返回當前偏移量,相當於seek
的對偶函數。
在對档案操作結束後,需要使用f.close()
將緩存中的字符串寫入硬盤;如果害怕發生意外,可以用f.flush()
強制寫入。
此外,档案對象的成員變量如下
name | mode | encoding | error | closed | buffer |
---|---|---|---|---|---|
档案名 | 讀寫模式 | 編碼方式 | 錯誤模式 | 是否已經關閉 | 緩沖區 |
此外還有三個判定函數
readable() |
writable() |
seekable |
---|---|---|
是否可讀 | 是否可寫 | 可否指定偏移量 |
with … as表達式
在寫入档案時,如果忘瞭close
或者flush
,那麼可能還有一些數據留在內存中,從而導致我們得到的档案是殘缺的。
with as
表達式可以通過調用對象中的__enter__
方法和__exit__
方法,來更加智慧地調用close
,從而免除瞭忘寫close
的麻煩。其調用方法為
with open('text.txt','w') as f: f.write("12345")
查看file.py
,其__exit__
函數正是close
:
def __enter__(self): return self def __exit__(self, type, value, traceback): self.close()
底層實現:os.open
open
是非常方便的函數,但開銷也很大,畢竟直接返回瞭一個档案對象。相比之下,其底層實現os.open
返回的是一個整型的档案ID,對於在速度上有要求的頻繁的档案讀寫操作,可以考慮使用。
os
中,打開一個档案的方法為
fd = os.open(path, flags, mode=511, dir_fd=None)
其中,
path
為档案路徑flags
為打開標志,例如os.O_RDONLY
代表隻讀、os.O_WRONLY
代表隻寫mode
表示档案權限,例如777代表任何人可讀可寫可執行;511代表档案創建者可讀可執行,其他人隻可讀,這屬於Linux的內容,日後可專門在Linux裡說。dir_fd
表示相對路徑的規則,為自定義函數,比較少用。- 最後,輸出的
fd
是某個档案的標識。
其中,mode的取值可見於deepin和windows的手冊,常用的標志如下,多個標志可通過|
疊加,這一股濃鬱的C風確認來自操作系統無疑瞭。
os.open | open | os.open | open |
---|---|---|---|
os.O_RDONLY | ‘r’ | os.O_WRONLY | ‘w’ |
os.O_RDWR | ‘r+’ | os.O_APPEND | ‘a’ |
os.O_CREAT | 創建並打開 |
其中相關的函數還有:
os.fdopen(fd, mode, bufsize) |
通過fd創建一個档案對象,並返回這個档案對象 |
os.read(fd, n) |
從fd 中讀取最多 n 個字節並返回,如果fd對應档案已達到結尾, 則返回空串。 |
os.write(fd, str) |
將str 寫入fd,返回實際寫入的字符串長度 |
os.fsync(fd) |
強制將fd所對應的档案寫入硬盤 |
os.close(fd) |
關閉fd |
os.dup(fd) |
復制fd |
os.dup2(fd, fd2) |
將fd1所對應的档案復制給fd2 |
os.fstat(fd) |
返回fd的狀態 |
os.ftruncate(fd, length) |
裁剪fd, length 不大於档案尺寸 |
os.isatty(fd) |
如果fd已經打開,同時與tty(-like)設備相連,則返回True, 否則False。 |
os.lseek(fd, pos, how) |
設置fd當前位置為pos, how為修改方式,等同於前文中的whence |
到此這篇關於深入解讀Python如何進行档案讀寫的文章就介紹到這瞭,更多相關Python 档案讀寫內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支援!
You may also like
相关贴文:
近期文章
- SHOPIFY REBELLON vs BOOM ESPORT [BO2] – TIMADO, YOPAJ 對上 JACKKY, MAC – ESL ONE BANGKOK 2024 DOTA 2
- Dota2 – Team Spirit VS Shopify Rebellion – ESL One 曼谷
- 德國滑雪選手如何打造 Shopify?
- 2024 年 12 月 2 款必銷產品🚀(Shopify 得獎者)
- Shopify Rebellon vs 獵鷹隊 [BO2] – TIMADO, YOPAJ 對 SKITER, AMMAR – ESL ONE BANGKOK 2024 DOTA 2
- 添加這些直銷產品並觀察您的銷售爆炸式增長#dropshipping #shopify
- 我如何在 19 歲時開始在 30 天內從巴基斯坦開始 Shopify Dropshipping 從 0 美元到 1000 美元
- 我打破了 Shopify 應用程式商店世界紀錄!
- 如何在 Shopify 上傳/更改封面主頁圖片
發佈留言