新聞中心
本篇內容介紹了“Python怎么讀寫二進制文件”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設,常熟企業(yè)網(wǎng)站建設,常熟品牌網(wǎng)站建設,網(wǎng)站定制,常熟網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,常熟網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
Python讀寫二進制文件
使用python語言直接讀取普通文件,可以使用
open('filepath/filename','r')
open函數(shù)中,第一個參數(shù)表示讀取文件的路徑,第二個參數(shù)表示打開文件的模式,
‘r’表示只讀(缺省,如果文件不存在,則會拋出錯誤)
‘w’表示只寫(如果文件不存在,則自動創(chuàng)建文件)
‘a(chǎn)’表示 新寫入的內容附加到文件的末尾
‘r+’表示 讀寫
如果要以二進制的方式打開文件,需要在第二個參數(shù)加上字符“b”(例如,“rb”,“wb”等)。
注意: 在讀取二進制文件時,使用linux系統(tǒng)可以不加“b”,但使用windows一定要“b”,否則會以普通文本形式讀取。
Python讀取二進制文件
讀取二進制文件并保存為Long型 (讀取原文件通過UltraEdit查看16進制編碼是“78 56 34 12”)
#以二進制的方式讀取文件 #coding: UTF-8 fileData = open('/home/ubuntu/staff_sample.dat','rb') #讀取文件的前4個字節(jié) #將讀取的4個字節(jié)轉換為long data_id = struct.unpack("l",fileData.read(4)) print data_id
打印的結果是305419896。
struct.unpack()函數(shù),第一個參數(shù)format表示轉換的類型,常用的有:
讀取二進制文件并保存為String類型
原始文件中字符串使用的是TCHAR類型,TCHAR類型的每個字符占2個字節(jié),這里的原始數(shù)據(jù)是”Staff 頭銜”,使用UE編輯器查看16進制編碼是
代碼:
data_string = fileData.read(128) readString1 = unicode(data_string,"utf-16") print readString1
代碼中,
第一句表示從二進制文件讀取128個字節(jié);
第二句表示將讀取出來的數(shù)據(jù)轉換成utf-16格式編碼的字符串。
說明:UTF-16是Unicode的其中一個使用方式,其編碼的方法是:
如果字符編碼U小于0×10000,也就是十進制的0到65535之內,則直接使用兩字節(jié)表示
如果字節(jié)編碼U大于0×10000,(由于Unicode編碼最大范圍是0x10FFFF),則使用4字節(jié)表示
python 寫入二進制文件
1.寫入long型數(shù)據(jù)
在上面提到python讀取二進制文件并轉化為long型,現(xiàn)在逆向將long保存到文件中,
#coding: UTF-8 id = 305419896 parsedata_id = struct.pack("L",id) #將long型305419896保存到二進制文件中 #將long型寫入到文件中 WriteFileData = open('/home/ubuntu/pythonfile.dat','wb') WriteFileData.write(parsedata_id) WriteFileData.close()
2. 將string類型寫入二進制文件
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表示后,默認UTF-16文件的開頭,都會自動放置一個U+FEFF字符作為Byte Order Mark(UTF-16以FF FE代表,UTF-16BE以FE FF代表),其中U+FEFF字符在Unicode中代表的意義是ZERO WIDTH NO-BREAK SPACE,即它表示沒有寬度也沒有斷字的空白。
如果寫入的二進制文件需要在C、C++語言中使用,或者需要與C、C++的程序通信時,則需要將FF FE字節(jié)刪除,也就是需要加入上述代碼中的第三行和第四行,如果只是用于python語言,可不用理會FF FE這兩個開頭字節(jié)。
“Python怎么讀寫二進制文件”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質量的實用文章!
當前文章:Python怎么讀寫二進制文件
標題路徑:http://fisionsoft.com.cn/article/ppshhg.html