встроенный qtconsole в приложении pyqt5 не работает должным образом

1

У меня довольно большой проект со встроенным Jupyter QtConsole 4.4.2.

Для получения более подробной информации смотрите: https://github.com/3fon3fonov/trifon

Теперь, пока некоторые процессы запущены/завершены, я пытаюсь отправить некоторый текст в Qtconsole и использовать его в качестве экрана вывода (и наоборот, я хочу, чтобы Jupyter мог при необходимости управлять графическим интерфейсом, но это еще одна проблема, с которой мне придется иметь дело позже).

Проблема в том, что некоторые функции ConsoleWidget не работают, и я не могу найти причину этого...

Например, в моем основном коде GUI:

ConsoleWidget_embed().push_vars({'fit':fit}) <-- WORKS!   

ConsoleWidget_embed().clear() <-- Does not work!
ConsoleWidget_embed().print_text("Test string")  <-- Does not work!

Вот код, который я встраиваю в Qtab.

import numpy as np
import sys #,os
from PyQt5 import QtCore, QtGui, QtWidgets, uic

from qtconsole.rich_jupyter_widget import RichJupyterWidget
from qtconsole.inprocess import QtInProcessKernelManager
from qtconsole.console_widget import ConsoleWidget


class ConsoleWidget_embed(RichJupyterWidget,ConsoleWidget):
    global fit

    def __init__(self, customBanner=None, *args, **kwargs):
        super(ConsoleWidget_embed, self).__init__(*args, **kwargs)

        if customBanner is not None:
            self.banner = customBanner

        #self.font_size = 4
        self.kernel_manager =   QtInProcessKernelManager()
        self.kernel_manager.start_kernel(show_banner=True)
        self.kernel_manager.kernel.gui = 'qt'
        self.kernel = self.kernel_manager.kernel
        self.kernel_client = self._kernel_manager.client()
        self.kernel_client.start_channels()

        #self._execute("kernel = %s"%fit, False) 

        def stop():
            self.kernel_client.stop_channels()
            self.kernel_manager.shutdown_kernel()
            self.guisupport.get_app_qt().exit()

        self.exit_requested.connect(stop)


    def push_vars(self, variableDict):
        """
        Given a dictionary containing name / value pairs, push those variables
        to the Jupyter console widget
        """
        self.kernel_manager.kernel.shell.push(variableDict)

    def clear(self):
        """
        Clears the terminal
        """
        self._control.clear()

        # self.kernel_manager

    def print_text(self, text):
        """
        Prints some plain text to the console
        """
        self._append_plain_text(text, before_prompt=False)

    def execute_command(self, command):
        """
        Execute a command in the frame of the console widget
        """
        self._execute(command, False)




if __name__ == "__main__":
    app = QtWidgets.QApplication(sys.argv)
    main = mainWindow()
    main.show()
    sys.exit(app.exec_())  

Любые идеи будут высоко оценены!

Всего наилучшего, Трифон

Теги:
pyqt5
pyqt
qtconsole

1 ответ

1
Лучший ответ

Проблема в вашем случае заключается в том, что вы создаете ConsoleWidget_embed каждый раз, когда вы вводите ConsoleWidget_embed(), вместо этого создаете объект этого класса и устанавливаете его как атрибут класса:

    self.console_widget = ConsoleWidget_embed()
    self.terminal_embeded.addTab(self.console_widget, "Jupyter")

    # ...

def jupiter_push_vars(self):
    global fit        
    self.console_widget.push_vars({'fit':fit})   
    self.console_widget.clear()
    self.console_widget.print_text("Test string")
  • 0
    Точно как всегда! Спасибо eyllanesc, я все еще удивляюсь, почему я не осознавал этого раньше!
  • 0
    OK eyllanesc, может быть, это не то место, но, поскольку эта проблема решена, можете ли вы посоветовать, как "вытянуть" переменные / объекты из "console_widget" в основной виджет? Например, если я наберу в оболочке Jupyter "fit.epoch = 0", чтобы получить это в графическом интерфейсе?
Показать ещё 2 комментария

Ещё вопросы

Сообщество Overcoder
Наверх
Меню