我正在構建一個簡單的 GUI,但在嘗試將事件變量傳遞給另一個已經具有事件變量的函數時遇到了問題。我正在嘗試將變量“sqlItemx”(它是“self.item1”的事件變量)用于函數“addNumbs”。如何傳遞此變量以供以后使用?我試過簡單地按照通常的約定傳遞變量,但這對我不起作用。下面列出了我的代碼摘錄:def listitems(self, event): for widget in self.itemFrame.winfo_children(): widget.destroy() searchLettersx = event.widget['text'] mycursor.execute("SELECT Name FROM inventory WHERE Name LIKE '" + searchLettersx + "%' ") myresult = mycursor.fetchall() rcount = 0 ccount = 0 for y in myresult: self.item1 = tk.Button(self.itemFrame, text=y, bg='white', fg='deep sky blue', font=("Helvetica", 18), height='4', width='22') self.item1.grid(column=ccount, row=rcount) self.item1.bind('<Button-1>', self.addtoCart) if rcount >= 5: ccount += 1 rcount = 0 rcount += 1 def addtoCart(self, event): win = tk.Toplevel(bg="white") win.wm_title("Add to Cart") sqlItemx = event.widget['text'] frame = tk.Frame(win) frame.grid() self.numpadFrame = tk.Frame(win, pady='20', bg="white") self.numpadFrame.grid(column='0', row='2') itemLabel = tk.Label(win, text=sqlItemx, bg="white", font=("Helvetica", 18), pady="30") itemLabel.grid(row=0, column=0) numLabel = tk.Label(win, text="How many? ", bg="white", font=("Helvetica", 18), pady="30", anchor='e', justify='left') numLabel.grid(row=1, column=0) numbers = ["1", "2", "3", "4" , "5" , "6" , "7" , "8" , "9" , " " , "0" , " "] count = 0 for r in range(4): for c in range(3): numpad = tk.Button(self.numpadFrame, text=numbers[count], height='4', width='8', bg='white', fg='deep sky blue', font=("Helvetica", 18)) numpad.grid(row=r+1,column=c) numpad.bind('<Button-1>', self.addNumbs) count += 1我的最終目標是能夠將此變量的值傳遞給“addNumbs”,并將其用作我的 MySQL 語句的變量“val”中的值之一。
1 回答
縹緲止盈
TA貢獻2041條經驗 獲得超4個贊
您不需要通過該bind方法將命令附加到按鈕;相反,您可以使用command關鍵字參數。
為了傳遞 item_type 參數,您需要遍歷與創建的每個按鈕對應的各種參數,并在創建按鈕時將它們包含在函數調用中。
也許是這樣的:
...
list_of_items = [item0, item1, item2, ...]
item_buttons = [] # keep a reference on each button
for y, item in enumerate(list_of_items):
btn = tk.Button(self.itemFrame, command=lambda item=item: self.addtoCart(item), ...)
item_buttons.append(btn)
btn.grid(column=ccount, row=rcount)
...
添加回答
舉報
0/150
提交
取消
