gpt4 book ai didi

python - Q : KDB+/PyQ publisher subscriber with feeds in python objects

转载 作者:太空宇宙 更新时间:2023-11-04 04:37:47 25 4
gpt4 key购买 nike

我一直在尝试重现发布者订阅者示例: https://code.kx.com/wiki/Cookbook/publishsubscribe

就纯 q 相关而言,一切正常。

我一直在尝试使用 PyQ 内核在 jupyter notebook 中重现订阅者。我没有设法在 python 对象中成功获取订阅者输出/提要。每一次,订阅者都会在内核输出(控制台)中打印。

我也一直在尝试在 PyQ 中复制一些类似于我在 q 的 java 客户端上看到的东西,但没有成功(https://code.kx.com/q/interfaces/java-client-for-q/)

我理想中想要实现的是:

  • 在命令行中运行我的发布者(到目前为止这是非常简单的部分)
  • 有一个 python notebook 可以监听我的发布者发布的端口,并在有新提要时处理事件
  • websocket 解决方案会很出色

有没有人对如何在 python 端执行此操作有一些指示?有什么例子吗?

非常感谢,耶尔达蒙

最佳答案

为了将 q 输出重定向到 Jupyter notebook,您应该为 %%q 单元魔法指定 -1(对于 stdout)和 -2(对于 stderr)选项。

I want it in a python object

您可以通过将标准流重定向到管道来捕获它们。例如,在 Linux 上你可以这样做

>>> import os
>>> r,w = os.pipe()
>>> q('\\2 /dev/fd/%d' % w)
k('::')
>>> q('-2 "hello"')
k('-2')
>>> os.read(r, 5)
b'hello'

请注意,我使用 stderr 进行说明,因为重定向 stdout 会干扰 REPL 显示,但同样的技术也适用于 stdout。使用管道的常见注意事项适用。管道的缓冲区有限,因此您需要安排定期读取。通常,这将涉及某种超出此答案范围的事件管理。如果您不想处理这种复杂性,最好的办法是使用临时文件而不是管道。我还建议研究如何在 pytest 中实现“fdcap”夹具。

关于python - Q : KDB+/PyQ publisher subscriber with feeds in python objects,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51290256/

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