一、python檔案讀寫的幾種模式:
r,rb,w,wb 那麼在讀寫檔案時,
有無b標識的的主要區別在**呢?
1、檔案使用方式標識
'r':預設值,表示從檔案讀取資料。
'w':表示要向檔案寫入資料,並截斷以前的內容
'a':表示要向檔案寫入資料,新增到當前內容尾部
'r+':表示對檔案進行可讀寫操作(刪除以前的所有資料)
'r+a':表示對檔案可進行讀寫操作(新增到當前檔案尾部)
'b':表示要讀寫二進位制資料
2、讀檔案 進行讀檔案操作時,直到讀到文件結束符(eof)才算讀取到檔案最後,python會認為位元組\x1a(26)轉換成的字元為文件結束符(eof),
故使用'r'進行讀取二進位制檔案時,可能會出現文件讀取不全的現象。
示例:二進位制檔案中存在如下從低位向高位排列的資料:7f 32 1a 2f 3d 2c 12 2e 76
如果使用'r'進行讀取,則讀到第三個位元組,即認為檔案結束。
如果使用'rb'按照二進位制位進行讀取的,不會將讀取的位元組轉換成字元,從而避免了上面的錯誤。
解決方案:
二進位制檔案就用二進位制方法讀取'rb'
總結:使用'r'的時候,如果碰到'0x1a',就視為檔案結束,就是eof。使用'rb'則不存在這個問題,
即:如果你用二進位制寫入再用檔案讀出的話,如果其中存在'0x1a',就只會讀出檔案的一部分,
使用'rb'會一直讀取檔案末尾。
3、寫檔案 對於字串x='abc\ndef',我們可用len(x)得到它的長度為7,\n我們稱之為換行符,實際上是0x0a。當我們用'w'即文字方式寫的時候,在windows平台上會自動將'0x0a'變成兩個字元'0x0d','0x0a',即檔案長度實際上變成8。當用'r'文字方式讀取時,又自動的轉換成原來的換行符。 如果換成'wb'二進位制方式來寫的話,則會保持乙個字元不變,讀取的時候也是原樣讀取。 所以如果用文字方式寫入,用二進位制方式讀取的話,就要考慮這多出的乙個位元組了。'0x0d'也稱回車符。 linux下不會變,因為linux只使用'0x0a'來表示換行。
Python open讀寫檔案實現指令碼
zz python中檔案操作可以通過open函式,這的確很像c語言中的fopen。通過open函式獲取乙個file object,然後呼叫read write 等方法對檔案進行讀寫操作。1.open 使用open開啟檔案後一定要記得呼叫檔案物件的close 方法。比如可以用try finally語句...
Python open讀寫檔案實現指令碼
python中檔案操作可以通過open函式,這的確很像c語言中的fopen。通過open函式獲取乙個file object,然後呼叫read write 等方法對檔案進行讀寫操作。1.open 使用open開啟檔案後一定要記得呼叫檔案物件的close 方法。比如可以用try finally語句來確保...
python open檔案 讀寫模式說明
r open for reading and writing.the stream is positioned at the beginning of the file.w open for reading and writing.the file is created if it does not...