本文小編為大家詳細(xì)介紹“Python中怎么進(jìn)行二進(jìn)制數(shù)據(jù)讀取操作”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Python中怎么進(jìn)行二進(jìn)制數(shù)據(jù)讀取操作”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識(shí)吧。
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站制作、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的天河網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
bytes:一種字符序列的類型。通過比較 dir(str) 與 dir(bytes) 可知,兩者的屬性與方法很相似,只有少數(shù)幾個(gè)不同。所以 bytes 也是可以像 string 一樣,對(duì)字節(jié)序列有各種操作方法,如查找(find),求長(zhǎng)度(len),切割(split),切片等。
bytes 的優(yōu)點(diǎn)是:Python 內(nèi)置的方法,不需要的額外的安裝三方模塊。
但缺點(diǎn)也很明顯:只能單個(gè)查詢,不能一次查詢多個(gè)需要的結(jié)果。
首先通過 open 的 rb 模式打開文件,讀取內(nèi)容為 bytes 類型。查找特定字符串有 find() 方法,但是此方法只能找到第一個(gè)符合要求的字符串索引,并且給出的不是單個(gè)位的索引,而是 8 位一個(gè)字節(jié)的索引。當(dāng)需要查找多個(gè)符合的字符串,卻沒有內(nèi)置的 findall() 方法。如果要查詢多個(gè),過程會(huì)麻煩,首先查到第一個(gè)符合的索引 1,以此索引 1 為開始,查詢第二個(gè)符合的索引 2,以此類推,直到查詢結(jié)束。
with open(path, 'rb') as f: datas = f.read() start_char = datas.find(b'Start') # start_char2 = datas.find(b'Start', start_char) end_char = datas.find(b'End', start_char) # end_char2 = datas.find(b'End', start_char2) data = datas[start_char:end_char] print(data)
注意上述代碼,start_char 和 end_char 會(huì)出現(xiàn)多次,次數(shù)并不一定會(huì)一樣,需要獲取兩個(gè)索引之間的內(nèi)容,但是既無法循環(huán),也不能一次查完。需要多次執(zhí)行已注釋的那行代碼,獲取關(guān)鍵字索引。由于不知道文件數(shù)據(jù)中會(huì)有多少個(gè)開始標(biāo)志,也就不知道執(zhí)行多少次,這應(yīng)該采用循環(huán)解決,但似乎沒有可供循環(huán)的變量。這使得問題更加復(fù)雜。
其次,由于是獲取兩個(gè)標(biāo)志之間的內(nèi)容,所以,以上過程需要執(zhí)行兩遍。因此過程更顯得繁雜無比。
因此,尋找新的方法,是完全必要的。
bitstring 是一個(gè)三方包,以字節(jié)流形式讀取二進(jìn)制文件。
bitstring.py 文件的第一句話是:This package defines classes that simplify bit-wise creation, manipulation and interpretation of data.
翻譯如下:這個(gè)包定義的類簡(jiǎn)化了數(shù)據(jù)的逐位創(chuàng)建、操作和解釋。
簡(jiǎn)單理解就是,直接操作 bytes 類型的數(shù)據(jù)。
有主要的四個(gè)類,如下:
Bits -- An immutable container for binary data.
BitArray -- A mutable container for binary data.
ConstBitStream -- An immutable container with streaming methods.
BitStream -- A mutable container with streaming methods.
Bits -- 二進(jìn)制數(shù)據(jù)的不可變?nèi)萜鳌?br/>BitArray -- 二進(jìn)制數(shù)據(jù)的可變?nèi)萜鳌?br/>ConstBitStream -- 具有流方法的不可變?nèi)萜鳌?br/>BitStream -- 具有流方法的可變?nèi)萜鳌?/p>
像 bytes 一樣,首先讀取文件內(nèi)容,查找關(guān)鍵字索引,切片獲取數(shù)據(jù)內(nèi)容。
# update at 2022/05/06 start # from bistring import ConstBitStream, BitStream from bitstring import ConstBitStream, BitStream # update at 2022/05/06 end hex_datas = ConstBitStream(filename=path) # 讀取文件內(nèi)容 start_char = b'Start' start_chars = hex_datas.findall(start_char, bytealigned=True) # 一次找到全部符合的,返回一個(gè)生成器 start_indexs = [] for start_char in start_chars: start_indexs.append(start_char) end_char = b'End' end_indexs = [] for start_index in start_indexs: end_chars = hex_datas.find(end_char, start=start_index, bytealigned=True) # 找到第一個(gè)符合的,返回元組 for end_char in end_chars: end_indexs.append(end_char) result = [] for i in range(min(len(start_indexs), len(end_indexs))): hex_data = hex_datas[start_indexs[i]:end_indexs[i]] str_data = BitStream.tobytes(hex_data).decode('utf-8') result.append(str_data)
代碼分析,首先導(dǎo)入需要的兩個(gè)類:ConstBitStream, BitStream。獲取文件內(nèi)容,findall() 查找所有符合的字符串索引,find() 查找第一個(gè)符合的字符串索引。取開始、結(jié)束兩個(gè)列表的較小值,切片獲取數(shù)據(jù),類型為 ‘bitstring.ConstBitStream’,BitStream.tobytes() 方法轉(zhuǎn)為 bytes 類型,中文字符會(huì)亂碼,所以再用 decode() 解碼,得到需要的字符串。
整個(gè)過程還是簡(jiǎn)潔、連續(xù)。代碼中用到了 findall()、find()、tobytes() 方法。此外還有許多小細(xì)節(jié)需要注意,比如,start_indexs 如果為空,后續(xù)的代碼就不該執(zhí)行了,end_indexs 為空亦是如此。
由此可見,bitstring 這個(gè)包還是比較好用的。根據(jù)需求,用到的方法比較少,其實(shí)還有許多其他的方法,按需選擇。
讀到這里,這篇“Python中怎么進(jìn)行二進(jìn)制數(shù)據(jù)讀取操作”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。