我不知道我在这件事上哪里出了问题。
这是我想要解码的数据。
('2','\x00','2','\x00','5','\x00','0','\x00',
'P','\x00','i','\x00','n','\x00','O','\x00','V','\x00',
'E','\x00','m','\x00','p','\x00','t','\x00','y','\x00')下面是代码:
s = bytes(struct.unpack('28c',fld_desc)).decode('utf-16')没有得到字符串'2250PinOVEmpty',我得到了这个..。非常奇怪的符号串:
⠧㈧Ⱐ❜砰〧Ⱐ✲✬‧屸〰✬‧㔧Ⱐ❜砰〧Ⱐ✰✬‧屸〰✬‧倧Ⱐ❜砰〧Ⱐ❩✬‧屸〰✬‧渧Ⱐ❜砰〧Ⱐ❏✬‧屸〰✬‧嘧Ⱐ❜砰〧Ⱐ❅✬‧屸〰✬‧洧Ⱐ❜砰〧Ⱐ❰✬‧屸〰✬‧琧Ⱐ❜砰〧Ⱐ❹✬‧屸〰✩我哪里出错了?
发布于 2015-02-08 08:44:17
如果您的fld_desc实际上只是字节字符串'2\x002\x005\x000\x00P\x00i\x00n\x00O\x00V\x00E\x00m\x00p\x00t\x00y\x00',而这是python 2,则只需执行以下操作
>>> fld_desc.decode('UTF-16-LE')
u'2250PinOVEmpty'您所犯的错误是根本不需要在这里使用struct.unpack。如果您这样做了,那么您必须注意到struct.unpack返回一个字符元组:
>>> struct.unpack(fld_desc)
('2', '\x00', '2', '\x00', '5', '\x00', '0', '\x00', 'P', '\x00', 'i', '\x00',
'n', '\x00', 'O', '\x00', 'V', '\x00', 'E', '\x00', 'm', '\x00', 'p', '\x00',
't', '\x00', 'y', '\x00')提供给bytes (毕竟它是python 2中str的同义词),使其成为一个新的字符串。
"('2', '\\x00', '2', '\\x00', '5', '\\x00', '0', '\\x00', 'P', '\\x00', 'i', '\\x00', 'n', '\\x00', 'O', '\\x00', 'V', '\\x00', 'E', '\\x00', 'm', '\\x00', 'p', '\\x00', 't', '\\x00', 'y', '\\x00')"其中解码的字符看起来主要是CJK字符和象形图的字符串。
“✨✲尧へ✰(8)Ⱗ✠硜〰Ⱗ✠✵尧へ✰〧Ⱗ✠硜〰Ⱗ✠❐尧へ✰椧Ⱗ✠硜〰Ⱗ✠❮尧へ✰伧Ⱗ✠硜〰Ⱗ✠❖尧へ✰䔧Ⱗ✠硜〰Ⱗ✠❭尧へ✰瀧Ⱗ✠硜〰Ⱗ✠❴尧へ✰礧Ⱗ✠硜〰⤧”
在小endian (UTF-16-LE),和
⠧(8)Ⱐ❜砰〧Ⱐ✲✬·屸〰✬·㔧Ⱐ❜砰〧Ⱐ✰✬·屸〰✬·倧Ⱐ❜砰〧Ⱐ❩✬·屸〰✬·渧Ⱐ❜砰〧Ⱐ❏✬·屸〰✬·嘧Ⱐ❜砰〧Ⱐ❅✬·屸〰✬·洧Ⱐ❜砰〧Ⱐ❰✬·屸〰✬·琧Ⱐ❜砰〧Ⱐ❹✬·屸〰✩
在大本营(UTF-16-BE)。
发布于 2015-02-08 08:40:25
加入这些字符,然后解码它:
>>> data = ('2','\x00','2','\x00','5','\x00','0','\x00',
... 'P','\x00','i','\x00','n','\x00','O','\x00','V','\x00',
... 'E','\x00','m','\x00','p','\x00','t','\x00','y','\x00')
>>> ''.join(data).decode('utf-16')
u'2250PinOVEmpty'https://stackoverflow.com/questions/28392105
复制相似问题