gpt4 book ai didi

Python 从 struct.unpack() 的输出解码 UTF-16

转载 作者:行者123 更新时间:2023-11-28 21:16:36 24 4
gpt4 key购买 nike

我不知道我哪里做错了。

这是我要解码的数据。

('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',而是得到了这个......非常奇怪的符号串:

⠧㈧Ⱐ❜砰〧Ⱐ✲✬‧屸〰✬‧㔧Ⱐ❜砰〧Ⱐ✰✬‧屸〰✬‧倧Ⱐ❜砰〧Ⱐ❩✬‧屸〰✬‧渧Ⱐ❜砰〧Ⱐ❏✬‧屸〰✬‧嘧Ⱐ❜砰〧Ⱐ❅✬‧屸〰✬‧洧Ⱐ❜砰〧Ⱐ❰✬‧屸〰✬‧琧Ⱐ❜砰〧Ⱐ❹✬‧屸〰✩

我哪里出错了?

最佳答案

如果您的 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')"

哪个解码看起来确实像大部分中日韩字符和象形图

"✨✲尧へ✰㈧Ⱗ✠硜〰Ⱗ✠✵尧へ✰〧Ⱗ✠硜〰Ⱗ✠❐尧へ✰椧Ⱗ✠硜〰Ⱗ✠❮尧へ✰伧Ⱗ✠硜〰Ⱗ✠❖尧へ✰䔧Ⱗ✠硜〰Ⱗ✠❭尧へ✰瀧Ⱗ✠硜〰Ⱗ✠❴尧へ✰礧Ⱗ✠硜〰⤧"

在小端 (UTF-16-LE) 和

"⠧㈧Ⱐ❜砰〧Ⱐ✲✬‧屸〰✬‧㔧Ⱐ❜砰〧Ⱐ✰✬‧屸〰✬‧倧Ⱐ❜砰〧Ⱐ❩✬‧屸〰✬‧渧Ⱐ❜砰〧Ⱐ❏✬‧屸〰✬‧嘧Ⱐ❜砰〧Ⱐ❅✬‧屸〰✬‧洧Ⱐ❜砰〧Ⱐ❰✬‧屸〰✬‧琧Ⱐ❜砰〧Ⱐ❹✬‧屸〰✩"

大端 (UTF-16-BE)。

关于Python 从 struct.unpack() 的输出解码 UTF-16,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28392105/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com