Я тоже попробовал так, как сначала предложил Хайнцдераугст:
button[i] = ttk.Button(loadProject, text=data_files[i], command = lambda i=data_files[i]:load(i)).grid(column=1, row=i, sticky=W)
Я также смог решить эту проблему, используя класс в качестве промежуточной части обратного вызова:
(Этот класс был вставлен в viewProject)
class Command:
def __init__(self, callback, *args, **kwargs):
self.callback = callback
self.args = args
self.kwargs = kwargs
def __call__(self):
return(self.callback(*self.args, **self.kwargs))
Затем я изменил определение вашей кнопки на:
button[i] = ttk.Button(loadProject, text=data_files[i], command = Command(load,data_files[i])).grid(column=1, row=i, sticky=W)
И, наконец, я изменил функцию загрузки, чтобы принять аргумент:
def load(myFile):
spamReader = csv.reader(open(myFile))
for row in spamReader:
a = list(row)
ttk.Label(loadProject, text=(a[0])).grid(column=4, row=0, sticky=W)
ttk.Label(loadProject, text=("\n"+a[1])).grid(column=4, row=1, sticky=W)
ttk.Label(loadProject, text=("\n"+a[2])).grid(column=4, row=2, sticky=W)
ttk.Label(loadProject, text=(a[3])).grid(column=4, row=3, sticky=W)
ttk.Label(loadProject, text=(a[4])).grid(column=4, row=4, sticky=W)
ttk.Label(loadProject, text=("\n"+a[5])).grid(column=4, row=5, sticky=W)
ttk.Label(loadProject, text=("\n"+a[6])).grid(column=4, row=6, sticky=W)
ttk.Label(loadProject, text=("\n\n"+a[7])).grid(column=4, row=7, sticky=W)
Я не уверен, что будет лучшей практикой, но оба работают.
(Конечно, лямбда-подход кажется более «питонным»)
Источник: https://code.activestate.com/recipes/66521-avoiding-lambda-in-writing-callback-functions/