詳解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把文件補到對應的大小,也可能是以一些隨機的內容加上去。
熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

熱門話題

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

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

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

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

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

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

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

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