Python - 以十六进制字节读取的问题

时间:2015-03-22 17:52:10

标签: python hex byte

我正在读一个包含十六进制字节的文件我相信,这是我写的:

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

2 个答案:

答案 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

  • H04 80而不是48
  • e65(正确)
  • l06 c0而不是6c
  • l6c(正确)
  • o06 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!