我正在读一个包含十六进制字节的文件我相信,这是我写的:
def ByteToHexToDec( byteStr ):
hex_list = [ "%02X" % ord(x) if "\\x" in r"%r" % x else x for x in byteStr];
return hex_list;
with open("file.z","rb") as lines:
for line in lines:
print ByteToHexToDec(line);
这是它返回的内容:
['04', '80', 'e', '06', 'C0', 'l', '06', 'F0', ',', '02', '00', 'w', '06', 'F0', 'r', '06', 'C0', 'd', '02', '10', '\n']
我很确定这说的是你好世界(或类似的东西),而且我知道“你好世界”的十字架。是这样的:
480065006C006C006F00200077006F0072006C00640021
如果你仔细观察,那么' 48'与hex_list中的前两个元素匹配,除了正在的零,并且字母e具有十六进制值65 ...
那么文件中的字节是否有错误?还是我错误地读了字节?
由于
该文件可以在这里下载: https://drive.google.com/file/d/0B84_Z1V4nj9SS0x4MlR0a2poMkE/view?usp=sharing
答案 0 :(得分:0)
十六进制文件的内容:
$ od -t x1z -w16 file.z
0000000 04 80 65 06 c0 6c 06 f0 2c 02 00 77 06 f0 72 06 >..e..l..,..w..r.<
0000020 c0 64 02 10 0a >.d...<
0000025
你在尝试什么?
$ echo 'hello world' | od -t x1z -w12
0000000 68 65 6c 6c 6f 20 77 6f 72 6c 64 0a >hello world.<
0000014
注意binascii模块中的hexlify / unhexlify https://docs.python.org/2/library/binascii.html
答案 1 :(得分:0)
文件中的每个其他字节都填充了一个起始和尾随0
:
H
是04 80
而不是48
e
是65
(正确)l
是06 c0
而不是6c
l
是6c
(正确)o
是06 f0
而不是6f
,
是2c
(正确)
(空格)为02 00
而非20
等。
如果您希望转回Hello, world
,则必须修复该损坏:
def repairbroken(bytestr):
bytestr = iter(bytestr)
for byte1, byte2, byte3 in zip(*([bytestr] * 3)):
# character 1 is bits 4-7 in the first byte and bits 0-3 in the second
char1 = chr((ord(byte1) & 0xff) << 4 | (ord(byte2) & 0xff) >> 4)
yield char1
yield byte3
演示:
>>> binary = '\x04\x80e\x06\xc0l\x06\xf0,\x02\x00w\x06\xf0r\x06\xc0d\x02\x10\n'
>>> print ''.join(repairbroken(binary))
Hello, world!