Python如何讀寫字節(jié)數(shù)據(jù)
問題
你想讀寫二進(jìn)制文件,比如圖片,聲音文件等等。
解決方案
使用模式為 rb 或 wb 的 open() 函數(shù)來讀取或?qū)懭攵M(jìn)制數(shù)據(jù)。比如:
# Read the entire file as a single byte stringwith open(’somefile.bin’, ’rb’) as f: data = f.read()# Write binary data to a filewith open(’somefile.bin’, ’wb’) as f: f.write(b’Hello World’)
在讀取二進(jìn)制數(shù)據(jù)時(shí),需要指明的是所有返回的數(shù)據(jù)都是字節(jié)字符串格式的,而不是文本字符串。 類似的,在寫入的時(shí)候,必須保證參數(shù)是以字節(jié)形式對外暴露數(shù)據(jù)的對象(比如字節(jié)字符串,字節(jié)數(shù)組對象等)。
討論
在讀取二進(jìn)制數(shù)據(jù)的時(shí)候,字節(jié)字符串和文本字符串的語義差異可能會(huì)導(dǎo)致一個(gè)潛在的陷阱。 特別需要注意的是,索引和迭代動(dòng)作返回的是字節(jié)的值而不是字節(jié)字符串。比如:
>>> # Text string>>> t = ’Hello World’>>> t[0]’H’>>> for c in t:... print(c)...Hello...>>> # Byte string>>> b = b’Hello World’>>> b[0]72>>> for c in b:... print(c)...72101108108111...>>>
如果你想從二進(jìn)制模式的文件中讀取或?qū)懭胛谋緮?shù)據(jù),必須確保要進(jìn)行解碼和編碼操作。比如:
with open(’somefile.bin’, ’rb’) as f: data = f.read(16) text = data.decode(’utf-8’)with open(’somefile.bin’, ’wb’) as f: text = ’Hello World’ f.write(text.encode(’utf-8’))
二進(jìn)制I/O還有一個(gè)鮮為人知的特性就是數(shù)組和C結(jié)構(gòu)體類型能直接被寫入,而不需要中間轉(zhuǎn)換為自己對象。比如:
import arraynums = array.array(’i’, [1, 2, 3, 4])with open(’data.bin’,’wb’) as f: f.write(nums)
這個(gè)適用于任何實(shí)現(xiàn)了被稱之為”緩沖接口”的對象,這種對象會(huì)直接暴露其底層的內(nèi)存緩沖區(qū)給能處理它的操作。 二進(jìn)制數(shù)據(jù)的寫入就是這類操作之一。
很多對象還允許通過使用文件對象的 readinto() 方法直接讀取二進(jìn)制數(shù)據(jù)到其底層的內(nèi)存中去。比如:
>>> import array>>> a = array.array(’i’, [0, 0, 0, 0, 0, 0, 0, 0])>>> with open(’data.bin’, ’rb’) as f:... f.readinto(a)...16>>> aarray(’i’, [1, 2, 3, 4, 0, 0, 0, 0])>>>
但是使用這種技術(shù)的時(shí)候需要格外小心,因?yàn)樗ǔ>哂衅脚_(tái)相關(guān)性,并且可能會(huì)依賴字長和字節(jié)順序(高位優(yōu)先和低位優(yōu)先)。
以上就是Python如何讀寫字節(jié)數(shù)據(jù)的詳細(xì)內(nèi)容,更多關(guān)于Python讀寫字節(jié)數(shù)據(jù)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. HTML中的XML數(shù)據(jù)島記錄編輯與添加2. 三個(gè)不常見的 HTML5 實(shí)用新特性簡介3. 淺談CSS不規(guī)則邊框的生成方案4. html中的form不提交(排除)某些input 原創(chuàng)5. asp在iis7報(bào)錯(cuò)行號不準(zhǔn)問題的解決方法6. msxml3.dll 錯(cuò)誤 800c0019 系統(tǒng)錯(cuò)誤:-2146697191解決方法7. CSS可以做的幾個(gè)令你嘆為觀止的實(shí)例分享8. 詳解盒子端CSS動(dòng)畫性能提升9. CSS linear-gradient屬性案例詳解10. CSS百分比padding制作圖片自適應(yīng)布局
