我想将 ipython qtconsole 作为子窗口放入 MDI pyqt 应用程序中,然后从 qtconsole 创建其他子窗口。所以嵌入式 qtconsole 需要能够访问应用程序的命名空间。根据ipython 文档中的这个页面,InProcessKernel 将是最好的解决方案。我从 python 终端运行了这个示例脚本(如下所示)(如果我从 ipython 运行它,我得到一个 MultipleInstanceError)。但是暂时忘记创建子窗口,首先我需要弄清楚如何将对象传递到嵌入式 qtconsole。
- 我第一次运行 inprocess_qtconsole.py 时,嵌入的 qtconsole 的命名空间是空的。为什么以前在初始 python 终端或脚本中创建的对象没有传递到嵌入式 qtconsole?
- 如果我关闭包含嵌入式 qtconsole 的应用程序,在初始终端中定义一些变量,然后再次运行脚本,为什么我现在可以访问这些变量以及来自脚本下的变量
if __name__ == __main__
? - 有没有办法启动嵌入式 qtconsole 而不会阻止我启动它的 python 终端?
我主要只是希望能够将 QMainWindow 实例传递给嵌入式 qtconsole,因为创建子窗口需要传递这个对象(类似于window.mdiArea.addSubWindow()
)。如果我运行脚本两次,它会以一种骇人听闻的方式工作。
顺便说一句,internal_ipkernel
最新版本的 ipython 中似乎缺少其他官方 ipython 示例(ipkernel_qtapp.py)中使用的模块。
运行 Python 2.7、IPython 2.2/2.3 和 Windows 8.1。
from __future__ import print_function
import os
from IPython.qt.console.rich_ipython_widget import RichIPythonWidget
from IPython.qt.inprocess import QtInProcessKernelManager
from IPython.lib import guisupport
def print_process_id():
print('Process ID is:', os.getpid())
def main():
# Print the ID of the main process
print_process_id()
app = guisupport.get_app_qt4()
# Create an in-process kernel
# >>> print_process_id()
# will print the same process ID as the main process
kernel_manager = QtInProcessKernelManager()
kernel_manager.start_kernel()
kernel = kernel_manager.kernel
kernel.gui = 'qt4'
kernel.shell.push({'foo': 43, 'print_process_id': print_process_id})
kernel_client = kernel_manager.client()
kernel_client.start_channels()
def stop():
kernel_client.stop_channels()
kernel_manager.shutdown_kernel()
app.exit()
control = RichIPythonWidget()
control.kernel_manager = kernel_manager
control.kernel_client = kernel_client
control.exit_requested.connect(stop)
control.show()
guisupport.start_event_loop_qt4(app)
if __name__ == '__main__':
test = 'hello'
main()