我正在使用带有ctypes的python来读取字节数组并将其存储在python bytearray中。然后,该数组作为UDP数据包传输。
我想将时间附加到这个字节数组,并且相信这样做的方法是:
t = time.time()
返回python float。然后找到它存储在内存中的位置,并提取表示float的字节数组(4或8,我不确定),并将这些字节附加到我现有的bytearray。
对感兴趣的字节码组成的UDP数据包加时间戳的任何建议。
我的最小代码如下:
class Host:
def __init__(self):
self.data = (ctypes.c_ubyte * 4112)()
self.data_p = ctypes.byref(self.data)
self.byte_data = bytearray(4120)
self.t = (ctypes.c_ubyte * 8)()
self.t_p = ctypes.byref(self.t)
self.t = time.time()
self.Data_UDP_IP = "127.0.0.1"
self.Data_UDP_PORT = 8992
self.DataSock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
def genBytearray(self)
<function that fills self.data with actual data>
data = ctypes.cast(self.data_p, ctypes.POINTER(ctypes.c_ubyte))
self.t = time.time()
t_cast = ctypes.cast(self.t_p, ctypes.POINTER(ctypes.c_ubyte))
self.byte_data[0:4112] = data[0:4112]
self.byte_data[4112:4120] = t_cast[0:8]
import time
import ctypes
import socket
Host1 = Host()
genBytearray(Host1)
Host1.DataSock.sendto(self.byte_data, (self.Data_UDP_IP, self.Data_UDP_PORT))
问题是,似乎t_cast总是等于0.我想通过调用:
self.t = time.time()
我实际上并没有把时间写到self.t_p指向的位置。已经坚持了一段时间,不禁认为有一个更简单的方法。我遇到过struct.pack,但是当我尝试使用它时,python似乎崩溃了。
答案 0 :(得分:0)
万一有人偶然发现:
t = (ctypes.c_double * 1)(time.time())
tnew = ctypes.cast(t, ctypes.POINTER((ctypes.c_uint8 * 8)))
tnew.contents[0:8]
提取time.time()返回的64位double的uint8表示。