Не уверен, какой экземпляр должен быть передан в аргумент - PullRequest
0 голосов
/ 11 марта 2019

Сообщение об ошибке

Exception in Tkinter callback
Traceback (most recent call last):
  File "C:\Users\Patrick\Anaconda3\lib\tkinter\__init__.py", line 1705, in __call__
    return self.func(*args)
  File "<string>", line 20, in set_training_data_directory
  File "<string>", line 252, in printer
AttributeError: 'Navigate' object has no attribute 'Listbox1'

В этом коде, если я вызываю функцию set_training_data_directory, он также должен вызывать принтер из Toplevel1, что он и делает.Однако, поскольку принтер метода ожидает self в качестве аргумента, любой экземпляр класса Navigate, который я передаю как объект, говорит: «У объекта нет атрибута« Listbox1 ».Я передал self и self.main_g в качестве аргумента и до сих пор получаю сообщение об ошибке: «У объекта нет атрибута« Listbox1 »

Имя модуля: All_Classes

import import_ipynb
import Navigator
import Listings
import Main_GUI

Имя модуля:Основной

from tkinter import *
import import_ipynb
import Main_GUI
root = Tk()
top = Main_GUI.Toplevel1(root)
root.mainloop()

Имя модуля: листинги

import import_ipynb
from tkinter import filedialog
import sys
import tkinter as tk
import os
import All_Classes

class Lists:
    #Making a Navigator Object
    #List of the training data
    def get_list_of_training_data(self):
        training_data_names = []
        directory = self.get_training_dir()        
        for classes in os.listdir(directory):
            for data in os.listdir(os.path.join(directory,classes)):
                print(data)
                training_data_names.append(data)
        return training_data_names

Имя модуля: навигатор

import import_ipynb
from tkinter import filedialog
import tkinter as tk
import All_Classes

class Navigate:  
    def __init__(self):
        #Global Navigation variables
        #Training data directory
        self.TRAINING_DIR = ''
        #Model directory for loading
        self.MODEL_DIR = ''
        #Sound file path for loading
        self.SOUND_FILE = ''

        self.listings = All_Classes.Listings.Lists

        #self.g = GUI.Toplevel1()
        self.main_g = All_Classes.Main_GUI.Toplevel1

    #Function for Data directory
    def set_training_data_directory(self):
        self.TRAINING_DIR = filedialog.askdirectory()
        p = self.listings.get_list_of_training_data(self)
        print(p)
        self.main_g.printer(self)

    def get_training_dir(self):
        return self.TRAINING_DIR

Имя модуля: Main_GUI

import import_ipynb
import All_Classes
import sys
import tkinter as tk
import tkinter.ttk as ttk
py3 = True

class Toplevel1:  
    def __init__(self, top=None):
        self.nav = All_Classes.Navigator.Navigate()
        #'''This class configures and populates the toplevel window.
        #  top is the,  toplevel containing window.'''
        _bgcolor = '#d9d9d9'  # X11 color: 'gray85'
        _fgcolor = '#000000'  # X11 color: 'black'
        _compcolor = '#d9d9d9' # X11 color: 'gray85'
        _ana1color = '#d9d9d9' # X11 color: 'gray85' 
        _ana2color = '#ececec' # Closest X11 color: 'gray92' 
        self.style = ttk.Style()

        top.geometry("832x674+650+150")


        self.style.configure('TNotebook.Tab', background=_bgcolor)
        self.style.configure('TNotebook.Tab', foreground=_fgcolor)
        self.style.map('TNotebook.Tab', background=
        [('selected', _compcolor), ('active',_ana2color)])
        self.TNotebook1 = ttk.Notebook(top)
        self.TNotebook1.place(relx=0.012, rely=0.0, relheight=0.895
               , relwidth=0.978)
        self.TNotebook1.configure(width=814)
        self.TNotebook1.configure(takefocus="")
        self.TNotebook1_t0 = tk.Frame(self.TNotebook1)
        self.TNotebook1.add(self.TNotebook1_t0, padding=3)


        self.TNotebook2 = ttk.Notebook(self.TNotebook1_t0)
        self.TNotebook2.place(relx=0.037, rely=0.113, relheight=0.461
                , relwidth=0.412)
        self.TNotebook2.configure(width=334)
        self.TNotebook2.configure(takefocus="")
        self.TNotebook2_t0 = tk.Frame(self.TNotebook2)
        self.TNotebook2.add(self.TNotebook2_t0, padding=3)
        self.TNotebook2.tab(0, text="Audio Files", compound="left", underline="-1"
                ,)
        self.TNotebook2_t0.configure(background="#d9d9d9")
        self.TNotebook2_t0.configure(highlightbackground="#d9d9d9")
        self.TNotebook2_t0.configure(highlightcolor="black")


        self.Button2 = tk.Button(self.TNotebook1_t0)
        self.Button2.place(relx=0.123, rely=0.78, height=40, width=190)
        self.Button2.configure(activebackground="#ececec")
        self.Button2.configure(activeforeground="#000000")
        self.Button2.configure(background="#d9d9d9")
        self.Button2.configure(disabledforeground="#a3a3a3")
        self.Button2.configure(foreground="#000000")
        self.Button2.configure(highlightbackground="#d9d9d9")
        self.Button2.configure(highlightcolor="black")
        self.Button2.configure(pady="0")
        self.Button2.configure(text='''Load Training Data''')
        self.Button2.configure(command= self.nav.set_training_data_directory)

        self.Listbox1 = tk.Listbox(self.TNotebook2_t0)
        self.Listbox1.place(relx=0.0, rely=0.0, relheight=1.008, relwidth=1.012)
        self.Listbox1.configure(background="white")
        self.Listbox1.configure(disabledforeground="#a3a3a3")
        self.Listbox1.configure(font="TkFixedFont")
        self.Listbox1.configure(foreground="#000000")
        self.Listbox1.configure(width=334)
        #Init Scrollbar object
        self.scroll1 = tk.Scrollbar(self.Listbox1)
        self.scroll1.configure(command=self.Listbox1.yview)
        self.Listbox1.configure(yscrollcommand = self.scroll1.set)

    def printer(self): 
        print("printer Reached")

        self.Listbox1.pack()
        self.scroll1.pack(side = "right",fill = 'y')

        for i in range(20):
            self.Listbox1.insert(tk.END,i)

IЯ довольно новый с объектом в Python.Если у вас есть ответ, я был бы признателен.Также это может быть плохим способом проектирования?

1 Ответ

0 голосов
/ 12 марта 2019

Хорошо.Я посмотрел, и определенно возникает проблема с тем, как вы пишете и используете классы.В Navigator вы вызываете класс Lists, но не создаете его экземпляр:

self.listings = All_Classes.Listings.Lists

Чтобы создать экземпляр, вы должны завершить имя класса круглыми скобками.Таким образом, когда вы запускаете метод get_list_of_training_data(self), отсутствует self для передачи, поскольку self является именем экземпляра.

То же самое с self.main_g = All_Classes.Main_GUI.Toplevel1.

С моей точки зрения, создается сложная структура классов, когда они вам действительно не нужны.Цитируя Джека Дидериха: «Подпись это не класс в том, что у него есть два метода, один из которых является init».Клип на YouTube: Прекратить писать классы

С моей стороны у меня проблемы с тем, чтобы запустить его без ошибок, потому что мой os.path.join() предоставляет неработающие пути, не знаю почему.

Но: посмотрите, сможете ли вы сделать код не таким расколотым, и я думаю, что будет легче обнаружить проблемы.

...