1

Я пытаюсь создать простой графический интерфейс с использованием tkinter для чтения в CSV, а затем запустить некоторые функции интеллектуального анализа текста. Мне трудно понять функцию обратного вызова tkinter. Следующий код был создан с использованием этого кода ToyMVC.Значение параметра Entry с использованием tkinter, MVC и Observables

Я могу получить графический интерфейс, но у меня возникли проблемы с получением самого правого виджета Entry (variable name = finalPathEntry) для обновления с введенным пользователем текстом из левого виджета, как только пользователь нажмет кнопку.

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

Бест,

import tkinter as tk 

class Observable: 
    def __init__(self, initialValue=None): 
     self.data = initialValue 
     self.callbacks = {} 

def addCallback(self, func): 
    self.callbacks[func] = 1 

def delCallback(self, func): 
    del self.callback[func] 

def _docallbacks(self): 
    for func in self.callbacks: 
     func(self.data) 

def set(self, data): 
    self.data = data 
    self._docallbacks() 

def get(self): 
    return self.data 

def unset(self): 
    self.data = None 


class Model: 
    def __init__(self): 
     self.csvPath = Observable("") 

    def addPath(self, value): 
     self.csvPath.set(self.csvPath.get()) 


class View(tk.Toplevel): 
    def __init__(self, master): 
     tk.Toplevel.__init__(self, master) 
     self.protocol('WM_DELETE_WINDOW', self.master.destroy) 
     tk.Label(self, text='Please input path to CSV').pack(side='left') 

     self.pathEntry = tk.Entry(self, width=50) 
     self.pathEntry.pack(side='left') 
     self.addButton = tk.Button(self, text='Read CSV', width=8) 
     self.addButton.pack(side='left') 
     self.path = tk.StringVar() 
     self.finalPathEntry = tk.Entry(self, width = 30, textvariable = self.path) 
     self.finalPathEntry.pack(side='left') 

    def setPath(self, value): 
     self.path.set(str(value)) 


class Controller: 
    def __init__(self, root): 
     self.model = Model() 
     self.model.csvPath.addCallback(self.pathChanged) 
     self.view1 = View(root) 
     self.view1.minsize(width = 500, height = 500) 
     self.view1.addButton.config(command=self.addPath) 
     self.pathChanged(self.model.csvPath.get()) 

    def addPath(self): 
     self.model.addPath(self.view1.pathEntry.get()) 

    def pathChanged(self, val): 
     self.view1.setPath(val) 


if __name__ == '__main__': 
    root = tk.Tk() 
    root.withdraw() 
    app = Controller(root) 
    root.mainloop() 

EDIT: Используя ответ ниже, я сосредоточил свой код. Вот обновленная и работает фрагмент кода:

import tkinter as tk 

class Observable: 
    def __init__(self, initialValue = None): 
     self.data = initialValue 
     self.callbacks = {} 

    def addCallback(self, func): 
     self.callbacks[func] = 1 

    def delCallback(self, func): 
     del self.callback[func] 

    def _docallbacks(self): 
     for func in self.callbacks: 
      func(self.data) 

    def set(self, data): 
     self.data = data 
     self._docallbacks() 

    def get(self): 
     return self.data 

    def unset(self): 
     self.data = None 

class Model: 
    def __init__(self): 
     self.csvPath = Observable("") 

    def addPath(self, value): 
     self.csvPath.set(self.csvPath.get()) 

class View(tk.Toplevel): 
    def __init__(self, master): 
     tk.Toplevel.__init__(self, master) 
     self.protocol('WM_DELETE_WINDOW', self.master.destroy) 
     tk.Label(self, text='Please input path to CSV').pack(side='left') 
     self.pathEntry = tk.Entry(self, width=50) 
     self.pathEntry.pack(side='left') 
     self.addButton = tk.Button(self, text='Read CSV', width=8) 
     self.addButton.pack(side='left') 
     self.path = tk.StringVar() 
     self.finalPathEntry = tk.Entry(self, width = 30, textvariable = self.path) 
     self.finalPathEntry.pack(side='left') 

    def setPath(self, value): 
     self.path.set(str(value)) 

class Controller: 
    def __init__(self, root): 
     self.model = Model() 
     self.model.csvPath.addCallback(self.pathChanged) 
     self.view1 = View(root) 
     self.view1.minsize(width = 500, height = 500) 
     self.view1.addButton.config(command = self.addPath) 
     self.pathChanged(self.model.csvPath.get()) 

    def addPath(self): 
     self.model.addPath(self.view1.pathEntry.get()) 

    def pathChanged(self, val): 
     self.view1.setPath(val) 

if __name__ == '__main__': 
    root = tk.Tk() 
    root.withdraw() 
    app = Controller(root) 
    root.mainloop() 
+0

Вам необходимо исправить отступ кода. –

ответ

1

Одна вещь об этом коде кажется очевидной: Функции начинаясь в

def addcallback(self, func): 

до

def unset(self): 

не являются частью Наблюдаемой классы. Таким образом, аргумент «я» - это не то, что вы ожидаете от него. Вы должны отступать от этих функций.