我有一个需要以十六进制显示的二进制文件。代码如下:
file=open('myfile.chn','rb')
for x in file:
i=0
while i<len(x):
print ("%0.2X"%(x[i]))
i=i+1
if (i>=10):
i=0
break
file.close()
我得到的结果如下:
FF
FF
01
00
01
00
35
36
49
EC
.
.
.
为了显示结果,我需要更改哪部分代码如下?
FF FF 01 00 01
00 35 36 49 EC
.
.
(每个字节之间有一个空格)
答案 0 :(得分:3)
因为你只使用了10个元素:
print(" ".join("%0.2X" % s for s in x[:10]))
或者如果你想包括整行:
print(" ".join("%0.2X" % s for s in x))
您的初始版本仍有错误。您的输入每行读取一个字符串。类型转换“%0.2X”失败(“%s”有效)。我想你不能每行读取二进制文件。 \ n只是另一个字节,不能解释为换行符。
如果有一系列int值,则可以使用group方法创建n个元素的分区。组方法位于itertools recipies。
from itertools import zip_longest
def grouper(n, iterable):
args = [iter(iterable)] * n
return zip_longest(fillvalue=None, *args)
width=10
x = range(1,99)
for group in grouper(width, x):
print((" ".join("%0.2X" % s for s in group if s)))
输出:
01 02 03 04 05 06 07 08 09 0A
0B 0C 0D 0E 0F 10 11 12 13 14
15 16 17 18 19 1A 1B 1C 1D 1E
1F 20 21 22 23 24 25 26 27 28
29 2A 2B 2C 2D 2E 2F 30 31 32
33 34 35 36 37 38 39 3A 3B 3C
3D 3E 3F 40 41 42 43 44 45 46
47 48 49 4A 4B 4C 4D 4E 4F 50
51 52 53 54 55 56 57 58 59 5A
5B 5C 5D 5E 5F 60 61 62
to bytes_from_file将字节读取为生成器:
def bytes_from_file(name):
with open(name, 'rb') as fp:
def read1(): return fp.read(1)
for bytes in iter(read1, b""):
for byte in bytes:
yield byte
x = bytes_from_file('out.fmt') #replaces x = range(1,99)
答案 1 :(得分:1)
这应该这样做。
for i, x in enumerate(file):
print ("%0.2X" % (x)),
if i > 0 and i % 5 == 0:
print
答案 2 :(得分:0)
file=open('myfile.chn','rb')
for x in file:
char=0
i=0
while i<len(x):
print ("%0.2X "%(x[i])),
char += 1
if char == 5:
char=0
print ''
i=i+1
if (i>=10):
i=0
break
file.close()