Kivy не удается выполнить MainApp.run()

#python-3.x #kivy

#python-3.x #kivy

Вопрос:

Сегодня мое приложение Kivy внезапно перестало работать без каких-либо изменений с моей стороны… Может быть, из-за того, что новая версия Kivy что-то нарушает? Есть предположения?

Вот несколько строк кода, которые, по-видимому, вызывают ошибку:

 class MemppApp(App):


    def build(self):        
        curdir = dirname(__file__)
        self.IDdisplayed=1
        mainDisplay = affichage( )
        return mainDisplay

if __name__ == '__main__':
    MemppApp().run() #here is the line 1308 it's complaining about...
 

Это одна строка, запускающая основное приложение.

Вот мой вывод:

 [INFO   ] [Logger      ] Record log in /home/vince/.kivy/logs/kivy_20-12-27_5.txt
[INFO   ] [Kivy        ] v2.0.0
[INFO   ] [Kivy        ] Installed at "/usr/lib/python3/dist-packages/kivy/__init__.py"
[INFO   ] [Python      ] v3.8.5 (default, Jul 28 2020, 12:59:40) 
[GCC 9.3.0]
[INFO   ] [Python      ] Interpreter at "/usr/bin/python3"
[INFO   ] [Factory     ] 186 symbols loaded
[INFO   ] [Image       ] Providers: img_tex, img_dds, img_sdl2, img_pil (img_ffpyplayer ignored)
[INFO   ] [Text        ] Provider: pil(['text_sdl2'] ignored)
[INFO   ] [Window      ] Provider: sdl2
[INFO   ] [GL          ] Using the "OpenGL" graphics system
[INFO   ] [GL          ] Backend used <sdl2>
[INFO   ] [GL          ] OpenGL version <b'4.6 (Compatibility Profile) Mesa 20.0.8'>
[INFO   ] [GL          ] OpenGL vendor <b'Intel'>
[INFO   ] [GL          ] OpenGL renderer <b'Mesa Intel(R) UHD Graphics 620 (KBL GT2)'>
[INFO   ] [GL          ] OpenGL parsed version: 4, 6
[INFO   ] [GL          ] Shading version <b'4.60'>
[INFO   ] [GL          ] Texture max size <16384>
[INFO   ] [GL          ] Texture max units <32>
[INFO   ] [Window      ] auto add sdl2 input provider
[INFO   ] [Window      ] virtual keyboard not allowed, single mode, not docked
[INFO   ] [AudioGstplayer] Using Gstreamer 1.16.2.0
[INFO   ] [Audio       ] Providers: audio_gstplayer, audio_sdl2 (audio_ffpyplayer ignored)
 Traceback (most recent call last):
   File "/home/vince/Documents/programmes/Mempp/main.py", line 1308, in <module>
     MemppApp().run()
   File "/usr/lib/python3/dist-packages/kivy/app.py", line 949, in run
     self._run_prepare()
   File "/usr/lib/python3/dist-packages/kivy/app.py", line 918, in _run_prepare
     self.load_kv(filename=self.kv_file)
   File "/usr/lib/python3/dist-packages/kivy/app.py", line 691, in load_kv
     root = Builder.load_file(rfilename)
   File "/usr/lib/python3/dist-packages/kivy/lang/builder.py", line 306, in load_file
     return self.load_string(data, **kwargs)
   File "/usr/lib/python3/dist-packages/kivy/lang/builder.py", line 404, in load_string
     widget = Factory.get(parser.root.name)(__no_builder=True)
   File "/home/vince/Documents/programmes/Mempp/main.py", line 1126, in __init__
     self.menu = Menu( self.configChange, self.searchPage)
   File "/home/vince/Documents/programmes/Mempp/main.py", line 719, in __init__
     self.sliders = slidersFreq()
   File "/home/vince/Documents/programmes/Mempp/main.py", line 777, in __init__
     self.loadSliders()
   File "/home/vince/Documents/programmes/Mempp/main.py", line 808, in loadSliders
     s = Slider( min=0,
   File "/usr/lib/python3/dist-packages/kivy/uix/widget.py", line 350, in __init__
     super(Widget, self).__init__(**kwargs)
   File "kivy/_event.pyx", line 245, in kivy._event.EventDispatcher.__init__
 TypeError: object.__init__() takes exactly one argument (the instance to initialize)
 

Ответ №1:

Эта ошибка означает, что вы передаете аргумент, который класс не ожидает / обрабатывает, поэтому он передается суперклассам super , и они передают его по очереди. Когда он достигает object , выдается эта ошибка.

Невозможно быть более конкретным, потому что вы не предоставили минимальный исполняемый пример или соответствующий код. Обратите внимание, что трассировка отслеживает код в вашем main.py то, что вы здесь не разместили.

Комментарии:

1. Спасибо, это помогло мне, хотя мой вопрос был недостаточно подробным!

Ответ №2:

Спасибо, это помогло: ошибка была исправлена из-за этого фрагмента кода, который я не ставил раньше:

 s = Slider( min=0, max=100, value=Valeur, id = Clef)
 

Я думаю, это потому, что свойство id устарело, как указано в примечаниях к выпуску Kivy 2.0.0:
https://github.com/kivy/kivy/releases/tag/2.0.0
(при «критических изменениях»)

[#6677]: Виджет: удалить идентификатор из виджета.