python中rb含義理解
Python文件讀寫的幾種模式:
r,rb,w,wb 那么在讀寫文件時,有無b標(biāo)識的的主要區(qū)別在哪里呢?
文件使用方式標(biāo)識
’r’:默認(rèn)值,表示從文件讀取數(shù)據(jù) ’w’:表示要向文件寫入數(shù)據(jù),并截斷以前的內(nèi)容 ’a’:表示要向文件寫入數(shù)據(jù),添加到當(dāng)前內(nèi)容尾部 ’r+’:表示對文件進行可讀寫操作(刪除以前的所有數(shù)據(jù)) ’r+a’:表示對文件可進行讀寫操作(添加到當(dāng)前文件尾部) ’b’:表示要讀寫二進制數(shù)據(jù)。讀文件 進行讀文件操作時,直到讀到文檔結(jié)束符(EOF)才算讀取到文件最后,Python會認(rèn)為字節(jié)x1A(26)轉(zhuǎn)換成的字符為文檔結(jié)束符(EOF),
故使用’r’進行讀取二進制文件時,可能會出現(xiàn)文檔讀取不全的現(xiàn)象。
示例:
二進制文件中存在如下從低位向高位排列的數(shù)據(jù):7F 32 1A 2F 3D 2C 12 2E 76
如果使用’r’進行讀取,則讀到第三個字節(jié),即認(rèn)為文件結(jié)束。
如果使用’rb’按照二進制位進行讀取的,不會將讀取的字節(jié)轉(zhuǎn)換成字符,從而避免了上面的錯誤。
解決方案:
二進制文件就用二進制方法讀取’rb’
總結(jié):
使用’r’的時候,如果碰到’0x1A’,就視為文件結(jié)束,就是EOF。使用’rb’則不存在這個問題,
即:如果你用二進制寫入再用文件讀出的話,如果其中存在’0x1A’,就只會讀出文件的一部分,使用’rb’會一直讀取文件末尾。
知識點擴展:
r是讀取人工書寫的數(shù)據(jù),書寫的時候是什么樣子,讀出來就是什么樣。 rb是讀取二進制文件,非人工書寫的數(shù)據(jù)如.jpeg等這些。 另外encoding可以指定解碼格式,utf-8是現(xiàn)在的主流編碼方式,如果沒有指定encoding 的方式那么根據(jù)python版本的不同會有不同的解碼方式,Python3中是utf-8,而python2中是ascii。到此這篇關(guān)于python中rb含義理解的文章就介紹到這了,更多相關(guān)python中rb是什么意思內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 使用Python和百度語音識別生成視頻字幕的實現(xiàn)2. 淺談SpringMVC jsp前臺獲取參數(shù)的方式 EL表達(dá)式3. Java封裝數(shù)組實現(xiàn)包含、搜索和刪除元素操作詳解4. Gitlab CI-CD自動化部署SpringBoot項目的方法步驟5. ajax請求添加自定義header參數(shù)代碼6. JAVA上加密算法的實現(xiàn)用例7. 基于javascript處理二進制圖片流過程詳解8. Django-migrate報錯問題解決方案9. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)10. ASP中解決“對象關(guān)閉時,不允許操作。”的詭異問題……
