我有一个混合了字符和字节的列表,看起来像这样:
myData = ['a', '\x65', 'B', '\x66\x69', 'C']
我想把这个列表转换成字节数组,所以:
myByteArray = ['\x61' , '\x65', '\x42', '\x66', '\x69', '\x43']
到目前为止,我尝试的是在 myData 上进行简单显示 --
myData = ['a', '\x65', 'B', '\x66\x69', 'C']
print " ".join(hex(ord(n)) for n in myData)
由于数组中有一个元素恰好是两个字节,所以会抛出这个错误:
Traceback (most recent call last):
File "./test.py", line 3, in <module>
print " ".join(hex(ord(n)) for n in myData)
File "./test.py", line 3, in <genexpr>
print " ".join(hex(ord(n)) for n in myData)
TypeError: ord() expected a character, but string of length 2 found
如何将原始列表 myData 转换为字节数组 myByteArray?
最佳答案
您可以将它们全部合并并再次拆分以获得单独的字符,例如:
output_list = [hex(ord(c)) for c in ''.join(myData)]
尝试一下,
>>> myData = ['a', '\x65', 'B', '\x66\x69', 'C']
>>> [hex(ord(c)) for c in ''.join(myData)]
['0x61', '0x65', '0x42', '0x66', '0x69', '0x43']
关于python - 如何将字符和字节列表转换为纯字节列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19255012/