最初のパラメータとしてファイル名を持っている (このクラスはインviewProject内)erted
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/
おかげで、私はそれが今取り組んで持っています。私は2番目のものと一緒に行きました。なぜなら、私にとって理解しやすいように思えるからです。 – Launch