python中rb含義理解
Python文件讀寫的幾種模式:
r,rb,w,wb 那么在讀寫文件時,有無b標識的的主要區(qū)別在哪里呢?
文件使用方式標識
’r’:默認值,表示從文件讀取數(shù)據(jù) ’w’:表示要向文件寫入數(shù)據(jù),并截斷以前的內(nèi)容 ’a’:表示要向文件寫入數(shù)據(jù),添加到當前內(nèi)容尾部 ’r+’:表示對文件進行可讀寫操作(刪除以前的所有數(shù)據(jù)) ’r+a’:表示對文件可進行讀寫操作(添加到當前文件尾部) ’b’:表示要讀寫二進制數(shù)據(jù)。讀文件 進行讀文件操作時,直到讀到文檔結(jié)束符(EOF)才算讀取到文件最后,Python會認為字節(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é),即認為文件結(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. IntelliJ IDEA設置背景圖片的方法步驟2. 增大python字體的方法步驟3. JAMon(Java Application Monitor)備忘記4. Python OpenCV去除字母后面的雜線操作5. Python TestSuite生成測試報告過程解析6. docker /var/lib/docker/aufs/mnt 目錄清理方法7. Spring security 自定義過濾器實現(xiàn)Json參數(shù)傳遞并兼容表單參數(shù)(實例代碼)8. IntelliJ IDEA設置默認瀏覽器的方法9. Python os庫常用操作代碼匯總10. Java類加載機制實現(xiàn)步驟解析
