溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python怎么讀寫二進(jìn)制文件

發(fā)布時(shí)間:2021-08-12 15:18:12 來源:億速云 閱讀:594 作者:chen 欄目:編程語言

本篇內(nèi)容介紹了“Python怎么讀寫二進(jìn)制文件”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

Python讀寫二進(jìn)制文件

使用python語言直接讀取普通文件,可以使用

open('filepath/filename','r')

open函數(shù)中,第一個(gè)參數(shù)表示讀取文件的路徑,第二個(gè)參數(shù)表示打開文件的模式,

  • ‘r’表示只讀(缺省,如果文件不存在,則會(huì)拋出錯(cuò)誤)

  • ‘w’表示只寫(如果文件不存在,則自動(dòng)創(chuàng)建文件)

  • ‘a(chǎn)’表示 新寫入的內(nèi)容附加到文件的末尾

  • ‘r+’表示 讀寫

如果要以二進(jìn)制的方式打開文件,需要在第二個(gè)參數(shù)加上字符“b”(例如,“rb”,“wb”等)。

注意: 在讀取二進(jìn)制文件時(shí),使用linux系統(tǒng)可以不加“b”,但使用windows一定要“b”,否則會(huì)以普通文本形式讀取。

Python讀取二進(jìn)制文件

讀取二進(jìn)制文件并保存為Long型 (讀取原文件通過UltraEdit查看16進(jìn)制編碼是“78 56 34 12”)

    #以二進(jìn)制的方式讀取文件 #coding: UTF-8  
    fileData = open('/home/ubuntu/staff_sample.dat','rb')   #讀取文件的前4個(gè)字節(jié)   #將讀取的4個(gè)字節(jié)轉(zhuǎn)換為long data_id = struct.unpack("l",fileData.read(4)) print data_id

打印的結(jié)果是305419896。

struct.unpack()函數(shù),第一個(gè)參數(shù)format表示轉(zhuǎn)換的類型,常用的有:

Python怎么讀寫二進(jìn)制文件

讀取二進(jìn)制文件并保存為String類型

原始文件中字符串使用的是TCHAR類型,TCHAR類型的每個(gè)字符占2個(gè)字節(jié),這里的原始數(shù)據(jù)是”Staff 頭銜”,使用UE編輯器查看16進(jìn)制編碼是

Python怎么讀寫二進(jìn)制文件

代碼:

    data_string = fileData.read(128) readString1 = unicode(data_string,"utf-16") print readString1

代碼中,

第一句表示從二進(jìn)制文件讀取128個(gè)字節(jié);

第二句表示將讀取出來的數(shù)據(jù)轉(zhuǎn)換成utf-16格式編碼的字符串。

說明:UTF-16是Unicode的其中一個(gè)使用方式,其編碼的方法是:

  • 如果字符編碼U小于0×10000,也就是十進(jìn)制的0到65535之內(nèi),則直接使用兩字節(jié)表示

  • 如果字節(jié)編碼U大于0×10000,(由于Unicode編碼最大范圍是0x10FFFF),則使用4字節(jié)表示

python 寫入二進(jìn)制文件

1.寫入long型數(shù)據(jù)

在上面提到python讀取二進(jìn)制文件并轉(zhuǎn)化為long型,現(xiàn)在逆向?qū)ong保存到文件中,

    #coding: UTF-8   id = 305419896 parsedata_id = struct.pack("L",id) #將long型305419896保存到二進(jìn)制文件中 #將long型寫入到文件中 WriteFileData = open('/home/ubuntu/pythonfile.dat','wb') WriteFileData.write(parsedata_id) WriteFileData.close()

2. 將string類型寫入二進(jìn)制文件

    text = 'Staff 頭銜' text1 = text.encode("UTF-16") texlength = len(text1) text2 = text1[2:texlength] #將long型和string保存到文件中 WriteFileData = open('/home/ubuntu/pythonfile.dat','wb') WriteFileData.write(text2); WriteFileData.close()

解釋:上述代碼中的第二行將字符串采用UTF-16表示后,默認(rèn)UTF-16文件的開頭,都會(huì)自動(dòng)放置一個(gè)U+FEFF字符作為Byte Order Mark(UTF-16以FF FE代表,UTF-16BE以FE FF代表),其中U+FEFF字符在Unicode中代表的意義是ZERO WIDTH NO-BREAK SPACE,即它表示沒有寬度也沒有斷字的空白。

如果寫入的二進(jìn)制文件需要在C、C++語言中使用,或者需要與C、C++的程序通信時(shí),則需要將FF FE字節(jié)刪除,也就是需要加入上述代碼中的第三行和第四行,如果只是用于python語言,可不用理會(huì)FF FE這兩個(gè)開頭字節(jié)。

“Python怎么讀寫二進(jìn)制文件”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI