繁体   English   中英

Python编码问题

[英]Python Encoding Issues

我有要从Windows 1252中解码的数据,基本上我将代码发送到套接字,然后将其发送回去,我必须解码消息并使用IEEE-754从中获取特定值,但是我可以似乎找出所有这些编码的东西。 这是我的代码。

def printKinds ():
    test = "x40\x39\x19\x99\x99\x99\x99\x9A"

    print (byt1Hex(test))
    test = byt1Hex(test).replace(' ', '')
    struct.unpack('<d', binascii.unhexlify(test))
    print (test)
printKinds()

def byt1Hex( bytStr ):
    return ' '.join( [ "%02X" % ord( x ) for x in bytStr ] )

因此,我使用了它,然后必须从中获得价值。.但是它不起作用,我不知道为什么。

我得到的当前输出是

struct.unpack('<d', binascii.unhexlify(data))
struct.error: unpack requires a bytes object of length 8

我正在寻找的预期输出错误为25.1,但是当我对其进行编码时,它实际上将字符串更改为错误的值,因此在执行此操作时:

 print (byt1Hex(data))

我希望得到这个。

40 39 19 99 99 99 99 9A

但是我实际上得到了这个

78 34 30 39 19 99 99 99 99 9A
>>> import struct
>>> struct.pack('!d', 25.1)
b'@9\x19\x99\x99\x99\x99\x9a'
>>> struct.unpack('!d', _) #NOTE: no need to call byt1hex, unhexlify
(25.1,)

您通过网络发送,接收字节。 不需要将它们混合/分离。 除非协议要求(除非您在问题中提到协议)。

你有:

test = "x40\x39\x19\x99\x99\x99\x99\x9A"

你需要:

test = "\x40\x39\x19\x99\x99\x99\x99\x9A"

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM