Python如何讀寫字節(jié)數(shù)據(jù)
問題
你想讀寫二進制文件,比如圖片,聲音文件等等。
解決方案
使用模式為 rb 或 wb 的 open() 函數(shù)來讀取或?qū)懭攵M制數(shù)據(jù)。比如:
# Read the entire file as a single byte string
with open('somefile.bin', 'rb') as f:
data = f.read()
# Write binary data to a file
with open('somefile.bin', 'wb') as f:
f.write(b'Hello World')
在讀取二進制數(shù)據(jù)時,需要指明的是所有返回的數(shù)據(jù)都是字節(jié)字符串格式的,而不是文本字符串。 類似的,在寫入的時候,必須保證參數(shù)是以字節(jié)形式對外暴露數(shù)據(jù)的對象(比如字節(jié)字符串,字節(jié)數(shù)組對象等)。
討論
在讀取二進制數(shù)據(jù)的時候,字節(jié)字符串和文本字符串的語義差異可能會導致一個潛在的陷阱。 特別需要注意的是,索引和迭代動作返回的是字節(jié)的值而不是字節(jié)字符串。比如:
>>> # Text string >>> t = 'Hello World' >>> t[0] 'H' >>> for c in t: ... print(c) ... H e l l o ... >>> # Byte string >>> b = b'Hello World' >>> b[0] 72 >>> for c in b: ... print(c) ... 72 101 108 108 111 ... >>>
如果你想從二進制模式的文件中讀取或?qū)懭胛谋緮?shù)據(jù),必須確保要進行解碼和編碼操作。比如:
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'))
二進制I/O還有一個鮮為人知的特性就是數(shù)組和C結(jié)構(gòu)體類型能直接被寫入,而不需要中間轉(zhuǎn)換為自己對象。比如:
import array
nums = array.array('i', [1, 2, 3, 4])
with open('data.bin','wb') as f:
f.write(nums)
這個適用于任何實現(xiàn)了被稱之為”緩沖接口”的對象,這種對象會直接暴露其底層的內(nèi)存緩沖區(qū)給能處理它的操作。 二進制數(shù)據(jù)的寫入就是這類操作之一。
很多對象還允許通過使用文件對象的 readinto() 方法直接讀取二進制數(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
>>> a
array('i', [1, 2, 3, 4, 0, 0, 0, 0])
>>>
但是使用這種技術的時候需要格外小心,因為它通常具有平臺相關性,并且可能會依賴字長和字節(jié)順序(高位優(yōu)先和低位優(yōu)先)。
以上就是Python如何讀寫字節(jié)數(shù)據(jù)的詳細內(nèi)容,更多關于Python讀寫字節(jié)數(shù)據(jù)的資料請關注腳本之家其它相關文章!
相關文章
人工智能——K-Means聚類算法及Python實現(xiàn)
這篇文章主要介紹了人工智能——K-Means聚類算法及Python實現(xiàn),一個能夠找到我圈出的這?些點集的算法,就被稱為聚類算法,下面就來看看文章具體的介紹吧2022-01-01
VScode編寫第一個Python程序HelloWorld步驟
VScode是微軟去年推出的一款輕量級編輯器,功能上和Atom、Sublime Text、Vim類似,你可以通過配置將它打造成合適的IDE,這里簡單介紹一下,需要的朋友可以參考下2018-04-04

