首頁 後端開發 Python教學 詳解python檔案讀寫操作

詳解python檔案讀寫操作

Oct 19, 2016 am 11:57 AM
python

1.open

使用open開啟檔案後一定要記得呼叫檔案物件的close()方法。例如可以用try/finally語句來確保最後能關閉檔案。

file_object = open('thefile.txt')

try:

     all_the_text = file_object.read( )

語說明塊裡,因為當開啟檔案出現異常時,檔案物件file_object無法執行close()方法。

2.讀取檔案

讀取文字檔案

input = open('data', 'r')

#第二個參數預設為r

input = open('data')

讀二進位檔案

input = open('data', 'rb')

 

讀取所有內容

file_object = open('thefile.txt')

try:the

):

finally:

     file_object.close( )

 

讀取固定位元組

file_object = openat🜓: 'rb'

file_object = openat🜓: 'rb'

       chunk = file_object.read(100 )

        if not chunk:

            break

       )

 

讀取每行

list_of_all_the_lines = file_object.readlines( )

如果檔案是文字檔案,也可以直接遍歷文件物件取得每行:

for line in file_object:

     process line

 

3.寫檔案

 

寫二進位檔案

output = open('data', 'wb')

 

追加寫檔案

output = 寫p'data', 'w = open('thefile.txt', 'w')

file_object.write(all_the_text)

file_object.close( )

 

.寫入多行在效能上會比使用write一次性寫入要高。

在處理日誌檔案的時候,常常會遇到這樣的情況:日誌檔案巨大,不可能一次性把整個檔案讀入到記憶體中進行處理,例如需要在一台物理記憶體為2GB 的機器上處理一個2GB 的日誌文件,我們可能希望每次只處理其中200MB 的內容。

在 Python 中,內建的 File 物件直接提供了一個 readlines(sizehint) 函數來完成這樣的事情。以下面的程式碼為例:

file = open('test.log', 'r')sizehint = 209715200   # 200Mposition = 0lines = file.readlines(sizehint)while not file.tell() - position 每次調用readlines(sizehint) 函數,會傳回大約200MB 的數據,而且所傳回的必然都是完整的行數據,大多數情況下,傳回的資料的位元組數會稍微比sizehint 指定的值大一點(除最後一次呼叫readlines(sizehint) 函數的時候)。通常情況下,Python 會自動將使用者指定的 sizehint 的值調整成內部快取大小的整數倍。

file在python中是一個特殊的類型,它用於在python程式中對外部的檔案進行操作。在python中一切都是對象,file也不例外,file有file的方法和屬性。以下先來看看如何建立一個file物件:

file(name[, mode[, buffering]]) 

file()函數用來建立一個file對象,它有一個名叫open(),可能更形像一些,它們是內建函數。來看看它的參數。它參數都是以字串的形式傳遞的。 name是檔案的名字。

mode是開啟的模式,可選的值為r w a U,分別代表讀取(預設) 寫入 新增支援各種換行符的模式。用w或a模式開啟檔案的話,如果檔案不存在,那就自動建立。此外,用w模式開啟一個已經存在的檔案時,原有文件的內容會被清空,因為一開始文件的操作的標記是在文件的開頭的,這時候進行寫操作,無疑會把原有的內容給抹掉。由於歷史的原因,換行符在不同的系統中有不同模式,比如在unix中是一個n,而在windows中是'rn',用U模式打開文件,就是支持所有的換行模式,也就說' r' 'n' 'rn'都可表示換行,會有一個tuple用來存貯這個檔案中用過的換行符。不過,雖說換行有多種模式,讀到python中統一用n代替。在模式字元的後面,還可以加上+ b t這兩種標識,分別表示可以對檔案同時進行讀寫操作和用二進位模式、文字模式(預設)開啟檔案。

buffering如果為0表示不進行緩衝;如果為1表示進行「行緩衝「;如果是一個大於1的數表示緩衝區的大小,應該是以位元組為單位的。

file物件有自己的屬性和方法。先來看看file的屬性。

closed #標記檔案是否已關閉,由close()改寫 

encoding #檔案編碼 

mode #開啟模式 

name #p 

化模式 

name #tu softspace #boolean型,一般為0,據說print

file的讀寫方法:

F.read([size]) #size為讀取的長度,以byte為單位 

F.readline([ size]) 

#讀一行,如果定義了size,有可能回傳的只是一行的一部分 

F.readlines([size]) 

#把文件每一行當作一個list的一個成員,並且回傳這個list 。其實它的內部是透過循環呼叫readline()來實現的。如果提供size參數,size是表示讀取內容的總長,也就是說可能只讀到文件的一部分。

F.write(str) 

#把str寫到文件中,write()不會在str後面加上一個換行符 

F.writelines(seq) 

#把seq的內容全部寫到文件中。這個函數也只是忠實地寫入,不會在每行後面加上任何東西。 

file的其他方法:

F.close() 

#關閉檔案。 python會在一個文件不用後自動關閉文件,不過這項功能沒有保證,最好還是養成自己關閉的習慣。如果一個檔案在關閉後還操作會產生ValueError 

F.flush() 

#將緩衝區的內容寫入硬碟 

F.fileno() 

#.com標籤「 

F.isatty() 

#檔案是否為終端設備檔案(unix系統中的) 

F.tell() 

#返回檔案作業標記的目前位置,以檔案的開頭為原點

F.next() 

#回到下一行,並將檔案操作標記位移到下一行。把一個file用於for ... in file這樣的語句時,就是呼叫next()函數來實現遍歷的。 

F.seek(offset[,whence]) 

#將文件打作業標記移到offset的位置。這個offset一般是相對於文件的開頭來計算的,一般為正數。但如果提供了whence參數就不一定了,whence可以為0表示從頭開始計算,1表示以目前位置為原點計算。 2表示以文件末端為原點進行計算。需要注意,如果文件以a或a+的模式打開,每次進行寫入操作時,文件操作標記會自動返回文件末尾。 

F.truncate([size]) 

#把檔案裁成規定的大小,預設的是裁切到目前檔案作業標記的位置。如果size比文件的大小還要大,依據系統的不同可能是不改變文件,也可能是用0把文件補到對應的大小,也可能是以一些隨機的內容加上去。


本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

mysql 是否要付費 mysql 是否要付費 Apr 08, 2025 pm 05:36 PM

MySQL 有免費的社區版和收費的企業版。社區版可免費使用和修改,但支持有限,適合穩定性要求不高、技術能力強的應用。企業版提供全面商業支持,適合需要穩定可靠、高性能數據庫且願意為支持買單的應用。選擇版本時考慮的因素包括應用關鍵性、預算和技術技能。沒有完美的選項,只有最合適的方案,需根據具體情況謹慎選擇。

HadiDB:Python 中的輕量級、可水平擴展的數據庫 HadiDB:Python 中的輕量級、可水平擴展的數據庫 Apr 08, 2025 pm 06:12 PM

HadiDB:輕量級、高水平可擴展的Python數據庫HadiDB(hadidb)是一個用Python編寫的輕量級數據庫,具備高度水平的可擴展性。安裝HadiDB使用pip安裝:pipinstallhadidb用戶管理創建用戶:createuser()方法創建一個新用戶。 authentication()方法驗證用戶身份。 fromhadidb.operationimportuseruser_obj=user("admin","admin")user_obj.

Navicat查看MongoDB數據庫密碼的方法 Navicat查看MongoDB數據庫密碼的方法 Apr 08, 2025 pm 09:39 PM

直接通過 Navicat 查看 MongoDB 密碼是不可能的,因為它以哈希值形式存儲。取回丟失密碼的方法:1. 重置密碼;2. 檢查配置文件(可能包含哈希值);3. 檢查代碼(可能硬編碼密碼)。

Python:探索其主要應用程序 Python:探索其主要應用程序 Apr 10, 2025 am 09:41 AM

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

如何針對高負載應用程序優化 MySQL 性能? 如何針對高負載應用程序優化 MySQL 性能? Apr 08, 2025 pm 06:03 PM

MySQL數據庫性能優化指南在資源密集型應用中,MySQL數據庫扮演著至關重要的角色,負責管理海量事務。然而,隨著應用規模的擴大,數據庫性能瓶頸往往成為製約因素。本文將探討一系列行之有效的MySQL性能優化策略,確保您的應用在高負載下依然保持高效響應。我們將結合實際案例,深入講解索引、查詢優化、數據庫設計以及緩存等關鍵技術。 1.數據庫架構設計優化合理的數據庫架構是MySQL性能優化的基石。以下是一些核心原則:選擇合適的數據類型選擇最小的、符合需求的數據類型,既能節省存儲空間,又能提升數據處理速度

2小時的Python計劃:一種現實的方法 2小時的Python計劃:一種現實的方法 Apr 11, 2025 am 12:04 AM

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

如何將 AWS Glue 爬網程序與 Amazon Athena 結合使用 如何將 AWS Glue 爬網程序與 Amazon Athena 結合使用 Apr 09, 2025 pm 03:09 PM

作為數據專業人員,您需要處理來自各種來源的大量數據。這可能會給數據管理和分析帶來挑戰。幸運的是,兩項 AWS 服務可以提供幫助:AWS Glue 和 Amazon Athena。

mysql 可以連接到 sql 服務器嗎 mysql 可以連接到 sql 服務器嗎 Apr 08, 2025 pm 05:54 PM

否,MySQL 無法直接連接到 SQL Server。但可以使用以下方法實現數據交互:使用中間件:將數據從 MySQL 導出到中間格式,然後通過中間件導入到 SQL Server。使用數據庫鏈接器:商業工具可提供更友好的界面和高級功能,本質上仍通過中間件方式實現。

See all articles