假设我在Python中使用Tkinter创建了以下按钮:

import Tkinter as Tk
win = Tk.Toplevel()
frame = Tk.Frame(master=win).grid(row=1, column=1)
button = Tk.Button(master=frame, text='press', command=action)

当我按下按钮时,方法操作被调用,但是如果我想将一些参数传递给方法操作呢?

我尝试了以下代码:

button = Tk.Button(master=frame, text='press', command=action(someNumber))

这只是立即调用方法,按下按钮什么也不做。


关于解决这个问题的标准技术(不是特定于tkinter的),请参阅Python参数绑定。在Tkinter(或其他GUI框架)中使用回调有一些特殊的考虑,因为回调的返回值是无用的。

如果您尝试在一个循环中创建多个button,并根据循环计数器向每个button传递不同的参数,则可能会因为所谓的延迟绑定而遇到问题。详情请参阅tkinter在for循环中创建按钮传递命令参数。


当前回答

button = Tk.Button(master=frame, text='press', command=lambda: action(someNumber))

应该能解决这个问题

其他回答

JasonPy -一些事情…

如果你在一个循环中插入一个按钮,它将会被一遍又一遍地创建……这可能不是你想要的。(也许是)……

它总是得到最后一个索引的原因是lambda事件在您单击它们时运行,而不是在程序启动时运行。我不确定100%你在做什么,但也许试着在创建时存储值,然后用按钮调用它。

例:(不要使用这段代码,只是一个例子)

for entry in stuff_that_is_happening:
    value_store[entry] = stuff_that_is_happening

然后你可以说....

button... command: lambda: value_store[1]

希望这能有所帮助!

我迟到了,但有一个很简单的方法。

import tkinter as tk
def function1(param1, param2):
    print(str(param1) + str(param2))

var1 = "Hello "
var2 = "World!"
def function2():
    function1(var1, var2)

root = tk.Tk()

myButton = tk.Button(root, text="Button", command=function2)
root.mainloop()

您只需将想要使用的函数包装到另一个函数中,并在按下按钮时调用第二个函数。

这也可以通过使用标准库functools中的partial来实现,如下所示:

from functools import partial
#(...)
action_with_arg = partial(action, arg)
button = Tk.Button(master=frame, text='press', command=action_with_arg)

Python为函数参数提供默认值的能力为我们提供了一条出路。

def fce(x=myX, y=myY):
    myFunction(x,y)
button = Tk.Button(mainWin, text='press', command=fce)

参见:https://tkdocs.com/shipman/extra-args.html

对于更多的按钮,你可以创建一个函数,返回一个函数:

def fce(myX, myY):
    def wrapper(x=myX, y=myY):
        pass
        pass
        pass
        return x+y
    return wrapper

button1 = Tk.Button(mainWin, text='press 1', command=fce(1,2))
button2 = Tk.Button(mainWin, text='press 2', command=fce(3,4))
button3 = Tk.Button(mainWin, text='press 3', command=fce(9,8))
button = Tk.Button(master=frame, text='press', command=lambda: action(someNumber))

应该能解决这个问题