Текст отображается в окне отладки вместо всплывающего окна приложения Kivy - PullRequest
0 голосов
/ 17 февраля 2020

Я столкнулся с каким-то странным поведением Kivy, когда пытался поместить результаты некоторого анализа во всплывающее окно моего приложения. При активации кнопки я могу получить всплывающее окно (в котором должны отображаться результаты анализа, но оно пустое), а затем мои результаты отображаются в окне отладки. Но я хотел бы видеть их во всплывающем окне. Нет ошибок, нет трассировки, просто странность.

Вот как это выглядит:

enter image description here

Это строка, которая запускает popup:

show_syllsoutput_popup()

Эта строка должна заполнить ее, но вместо этого заполняет окно отладки:

try: SyllOutputPopup.screen_output_label.text = cfd_syll.tabulate()

Итак, вопрос в том, как поместить cfd_syll.tabulate() в это всплывающее окно (. kv):

<SyllOutputPopup>:

    FloatLayout:

        Label:

            id: screen_output_label
            font_size: 12
            pos: 100, 120

===================================== =======================

Альтернативный тест: если я попытаюсь заполнить всплывающее окно вывода следующим образом:

SyllOutputPopup.screen_output_label.text = cfd_syll.tabulate()

(без try:), я получаю AttributeError: type object 'SyllOutputPopup' has no attribute 'screen_output_label'

Вот полный трекбек, на случай, если это будет полезно:

File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\runpy.py", line 193, in _run_module_as_main
  "__main__", mod_spec)
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\runpy.py", line 85, in _run_code
  exec(code, run_globals)
File "C:\GUI Projects\gercort\main.py", line 190, in <module>
  Gercort().run()
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\app.py", line 855, in run
  runTouchApp()
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\base.py", line 504, in runTouchApp
  EventLoop.window.mainloop()
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\core\window\window_sdl2.py", line 747, in mainloop
  self._mainloop()
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\core\window\window_sdl2.py", line 479, in _mainloop
  EventLoop.idle()
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\base.py", line 342, in idle
  self.dispatch_input()
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\base.py", line 327, in dispatch_input
  post_dispatch_input(*pop(0))
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\base.py", line 293, in post_dispatch_input
  wid.dispatch('on_touch_up', me)
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\_event.cp37-win32.pyd", line 707, in kivy._event.EventDispatcher.dispatch
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\uix\behaviors\button.py", line 179, in on_touch_up
  self.dispatch('on_release')
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\_event.cp37-win32.pyd", line 703, in kivy._event.EventDispatcher.dispatch
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\_event.cp37-win32.pyd", line 1214, in kivy._event.EventObservers.dispatch
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\_event.cp37-win32.pyd", line 1098, in kivy._event.EventObservers._dispatch
File "C:\Users\gavrk\AppData\Local\Programs\Python\Python37-32\Lib\site-packages\kivy\lang\builder.py", line 64, in custom_callback
  exec(__kvlang__.co_value, idmap)
File "C:\GUI Projects\gercort\gercort.kv", line 484, in <module>
  on_release: root.output_toscreen(root.filepath)
File "C:\GUI Projects\gercort\main.py", line 135, in output_toscreen
  SyllOutputPopup.screen_output_label.text = cfd_syll.tabulate() # populate the popup

builtins.AttributeError: type object 'SyllOutputPopup' has no attribute 'screen_output_label'

Буду благодарен за любую помощь! Я не знаю, какие части кода были бы полезны, поэтому я заранее извиняюсь, любые предложения приветствуются.

=================== ===============================================

Дополнительная информация:

cfd_syll определяется в четвертой строке:

    def output_toscreen(сorpus_root, *args):

        corpus = PlaintextCorpusReader(args[0], '.*')
        cfd_syll = nltk.ConditionalFreqDist(
            (textname, num_syll)
            for textname in corpus.fileids()
            for num_syll in [len(w) for w in ''.join(char for char in reduce_dip(corpus.raw(fileids=textname)) if char in vowels).split()])

        show_syllsoutput_popup() # run the popup

        try: SyllOutputPopup.screen_output_label.text = cfd_syll.tabulate() # populate the popup

        except: pass

Вот класс Popup:

class SyllOutputPopup(FloatLayout):
    pass

Вот определение из show_syllsoutput_popup:

def show_syllsoutput_popup():
    show = SyllOutputPopup() # Create a new instance of the LicensePopup class 

    SyllOutputPopupWindow = Popup(title="Output", content=show, size_hint=(None,None),size=(600,400)) 
    # Create the popup window

    SyllOutputPopupWindow.open() # show the popup

В .kv Popup определяется как:

<SyllOutputPopup>:

    FloatLayout:

        Label:

            id: screen_output_label
            font_size: 12
            pos: 100, 120

1 Ответ

1 голос
/ 17 февраля 2020

screen_output_label не является параметром вашего класса, это идентификатор виджета, поэтому строка

SyllOutputPopup.screen_output_label.text = cfd_syll.tabulate()

неверна, вы должны использовать:

SyllOutputPopup.ids.screen_output_label.text = cfd_syll.tabulate()

====== ====

Также вы создаете несколько объектов класса SyllOutputPopup. Вы помещаете текст в один объект:

try: SyllOutputPopup.ids.screen_output_label.text = cfd_syll.tabulate()

А затем вы создаете новый объект, который является пустым и имеет пустую метку, и вы показываете его:

show = SyllOutputPopup() # Create a new instance
    SyllOutputPopupWindow = Popup(title="Output", content=show, size_hint=(None,None),size=(600,400)) 
    SyllOutputPopupWindow.open()

Вы должны использовать один object - установите текст там, а затем покажите именно этот объект, что-то вроде:

    def output_toscreen(сorpus_root, *args):

        corpus = PlaintextCorpusReader(args[0], '.*')
        cfd_syll = nltk.ConditionalFreqDist(
            (textname, num_syll)
            for textname in corpus.fileids()
            for num_syll in [len(w) for w in ''.join(char for char in reduce_dip(corpus.raw(fileids=textname)) if char in vowels).split()])
        # that will be your object
        self.sylloutputpopup = SyllOutputPopup()
        self.sylloutputpopup.ids.screen_output_label.text = cfd_syll.tabulate()
        show_syllsoutput_popup() # run the popup

def show_syllsoutput_popup():
    show = self.sylloutputpopup
    SyllOutputPopupWindow = Popup(title="Output", content=show, size_hint=(None,None),size=(600,400)) 
    SyllOutputPopupWindow.open()

Но это будет работать, только если обе функции выше находятся в одном классе.

...