通过zmq ipc发送现有的dict

che*_*oza 8 python zeromq

我正在尝试通过zmq ipc socket发送一个现有的dict,我可以用这段代码发送一个字符串,但我不能发送一个dict对象

import zmq, datetime

d = {0: ('356612022462768', 'EVENT', 0, '2012-12-26 15:50:16', -20.22216, -70.13723, 6.44, 134.0, 1, 2, '18743230', datetime.datetime(2013, 2, 10, 9, 6, 2, 362734))}

if __name__ == "__main__":
    context = zmq.Context()
    publisher = context.socket(zmq.PUB)
    publisher.connect("ipc://shared")
    while True:
        publisher.send( d )
        time.sleep( 1 )
Run Code Online (Sandbox Code Playgroud)
TypeError: {0: ('356612022462768', 'EVENT', 0, '2012-12-26 15:50:16', 
           -20.22216, -70.13723, 6.44, 134.0, 1, 2, '18743230', 
           datetime.datetime(2013, 2, 10, 9, 6, 2, 362734))} 
does not provide a buffer interface.
Run Code Online (Sandbox Code Playgroud)

我怎样才能做到这一点?

Jak*_*lås 9

只能通过ZeroMq发送字符串或字节数组,开箱即用.在将其传递给ZeroMq以便在线路上传输之前,还需要序列化任何其他内容.

您可以使用任何您喜欢的序列化它,例如Protocol Buffers,JSON或Message Pack.请注意,任何收件人都需要能够使用相同的协议反序列化数据.

您可以在此处找到有关如何结合pyzmq使用各种序列化技术(包括numpy数组)的示例.它们是pyzmq源代码的一部分.


Gle*_*eld 7

根据用例,您需要序列化数据,可能是JSON.你不能发送它,你需要一个字符串表示

import json
myjson = json.dumps(d)
Run Code Online (Sandbox Code Playgroud)

但是datetime对象不能简单地转换为json,所以你必须单独处理它,这篇文章将有助于:Python和JavaScript之间的JSON日期时间