1

有一个服务器发送 UPD 流 - 每秒 60 个数据包

我用twisted来阅读它:

from twisted.internet.protocol import DatagramProtocol
from twisted.internet import reactor
class Echo(DatagramProtocol):
    def datagramReceived(self, data, (host, port)):
        print ('1',data)
class Echo(DatagramProtocol):
reactor.listenUDP(port, Echo())
reactor.run()

在控制台中我喜欢:

('1', '\xea\xb6|C\x00\x00\x00\x00gK\xa0E\x00O\x05\xbd\x97\xb7\x04B\xf6\xfdY@\xb9\xa8\x0cD\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x004\x8e8\xbfKkv\xb3\xa6i1\xbf\xa6i1\xbf\x00\x00\x00\x004\x8e8?\xc0\x98\xed\xc1\xbd\x98\xed\xc1=\x1a\x9a\xc1\x96\x19\x9a\xc1\x9d\x88)\xba\x9fB,\xbaA\xb2\xa9;\xc5]\xd86\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x06\x00\x00\x80\xcd\xcc\xcc=\x00\x00\x80?\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xd4Q\x81@')
('1', '\x7f\xd5\x82D\x00\x00\x00\x00+8\x89Ed\xf0/\xbe\xbdy\x06D\x8b\xfaM@\xa9-ZD\x9f\x03EB\x89\xeb4\xc2Z+\x87\xbes\xf7\x9bAw\xc7\xca\xbeMv\x83\xbc\xc4\x07k\xbf\xd6\x06k\xbf\x93);\xbc\xd6\xe0\xca>m\xc4\xb5A\x7f\xdc\xd6A\xf7\x8arA!\xbdcAe\r\xb3B\xc4\xf7\xd3B*\\\xdeBWF\xe5B\xa5\xffBB\xddaCB\x8c EBL8EB\x00\x00\x807\x00\x00$\xbc\x00\x00\x807\x00\x00\x00\x00\x00\x00\xa0@F\xc6\xb1=(O\x12\xbf\x00\x00\x00\x00\x885\xa4D')

分析流量的人说:“通过它发出的数据包包含字段(38 个不同的字段)。所有字段都是浮点数据类型(在 C# 中)”

我知道有 38 个数字吗?我可以使用 Python 来阅读它们吗?

4

1 回答 1

3

您可以使用该struct模块:

floats = struct.unpack('<38f', data)

(您可能需要根据数据的字节顺序更改为。><

于 2012-04-11T13:03:58.923 回答