Python讀寫二進制文件使用python語言直接讀取普通文件,可以使用 open('filepath/filename','r')
open函數(shù)中,第一個參數(shù)表示讀取文件的路徑,第二個參數(shù)表示打開文件的模式,
如果要以二進制的方式打開文件,需要在第二個參數(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é)轉(zhuǎn)換為long
data_id = struct.unpack("l",fileData.read(4))
print data_id
打印的結果是305419896。 struct.unpack()函數(shù),第一個參數(shù)format表示轉(zhuǎn)換的類型,常用的有: 讀取二進制文件并保存為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ù)轉(zhuǎn)換成utf-16格式編碼的字符串。 說明:UTF-16是Unicode的其中一個使用方式,其編碼的方法是:
python 寫入二進制文件1.寫入long型數(shù)據(jù)在上面提到python讀取二進制文件并轉(zhuǎn)化為long型,現(xiàn)在逆向?qū)ong保存到文件中, #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é)。 |
|
|
來自: herowuking > 《Python》