>>> struct.pack('2I',12, 30)
b'\x0c\x00\x00\x00\x1e\x00\x00\x00'
>>> struct.pack('2I',12, 31)
b'\x0c\x00\x00\x00\x1f\x00\x00\x00'
>>> struct.pack('2I',12, 32)
b'\x0c\x00\x00\x00 \x00\x00\x00'
^in question
>>> struct.pack('2I',12, 33)
b'\x0c\x00\x00\x00!\x00\x00\x00'
^in question
Run Code Online (Sandbox Code Playgroud)
我希望所有值都显示为十六进制
他的怎么样?
>>> data = struct.pack('2I',12, 30)
>>> [hex(ord(c)) for c in data]
['0xc', '0x0', '0x0', '0x0', '0x1e', '0x0', '0x0', '0x0']
Run Code Online (Sandbox Code Playgroud)
表达式[item for item in sequence]是所谓的列表理解.它基本上是一种非常紧凑的方式来编写一个简单的for循环,并从结果中创建一个列表.
的ord()内置函数采用一个字符串,并把它转换成一个整数这是其相应的Unicode代码点(在ASCII字符集这是与它们在ASCII表值中的字符).
它的对应物,chr()对于8位字符串或unichr()对于unicode对象,则相反.
然后hex()内置函数只是将整数转换为十六进制表示.
正如@TimPeters所指出的,在Python 3中你需要丢失ord(),因为迭代一个字节对象将(已经)产生整数:
Python 3.4.0a3 (default, Nov 8 2013, 18:33:56)
>>> import struct
>>> data = struct.pack('2I',12, 30)
>>> type(data)
<class 'bytes'>
>>> type(data[1])
<class 'int'>
>>>
>>> [hex(i) for i in data]
['0xc', '0x0', '0x0', '0x0', '0x1e', '0x0', '0x0', '0x0']
Run Code Online (Sandbox Code Playgroud)
如果你想到处\x逃跑,你必须自己重新格式化; 例如,
>>> import struct
>>> r = struct.pack('2I',12, 33)
>>> r
b'\x0c\x00\x00\x00!\x00\x00\x00'
>>> list(r)
[12, 0, 0, 0, 33, 0, 0, 0]
>>> print("".join("\\x%02x" % i for i in r))
\x0c\x00\x00\x00\x21\x00\x00\x00
Run Code Online (Sandbox Code Playgroud)
试试binascii.hexlify:
>>> import binascii
>>> import struct
>>> binascii.hexlify(struct.pack('2I',12,30))
b'0c0000001e000000'
>>> binascii.hexlify(struct.pack('2I',12,31))
b'0c0000001f000000'
>>> binascii.hexlify(struct.pack('2I',12,32))
b'0c00000020000000'
>>> binascii.hexlify(struct.pack('2I',12,33))
b'0c00000021000000'
Run Code Online (Sandbox Code Playgroud)
或者,如果您想要空格使其更具可读性:
>>> ' '.join(format(n,'02X') for n in struct.pack('2I',12,33))
'0C 00 00 00 21 00 00 00'
Run Code Online (Sandbox Code Playgroud)
Python 3.6+,使用f-strings:
>>> ' '.join(f'{n:02X}' for n in struct.pack('2I',12,33))
'0C 00 00 00 21 00 00 00'
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
19686 次 |
| 最近记录: |